# COMPUTER SYSTEMS COMPASS TRAINING MANUAL VOLUME II | | RECORD of REVISIONS | | | |-------------|----------------------------------------------------------------------------------------------|--|--| | REVISION | VISION NOTES | | | | A (3-1-66) | Final Edition Released. | | | | B (4-19-67) | Publications Change Order CA16274. Manual enlarged from one to three volumes, replacing | | | | | 3600 COMPASS Programming Guide, Pub. No. 60166700, which becomes Volume 2 of the new | | | | | 3-volume set. Miscellaneous corrections to Volume 2, pages 1-1, 1-21, 1-26, 2-10, 2-14, 7-3, | | | | | 7-10, 11-5, 12-26, 12-30, 13-25, 15-13, 15-18, 15-22, 15-30, 15-42, 16-6, 17-2, 17-3, 17-6, | | | | | 18-2, 18-6, 18-10, 18-14, 18-18, and 18-22. This edition obsoletes all previous editions. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Pub No. 60166700 © 1966, 1967 by Control Data Corporation Printed in United States of America $\begin{array}{lll} \textbf{Address comments concerning this} \\ \textbf{manual to:} \end{array}$ Control Data Corporation Marketing Training Department 8100 - 34th Avenue South Minneapolis, Minnesota 55440 #### FOREWORD This manual is intended as a guide in learning how to program the upper 3000 computer systems. It includes a hardware concept of the systems, the use of the COMPASS programming language, and the use of the SCOPE monitor. Step-by-step example problems, with and without given solutions, are included to develop the capability of using the language. This manual is a major revision to and a replacement for the 3600 Computer System COMPASS Programming Guide and retains the same publication number. It is now expanded to three volumes. #### Volume I This volume consists of three sections. The first section deals with the introduction to the systems. The second section deals with the central processor. The third section deals with problem-oriented exercises in which random instructions are picked to solve problems. #### Volume II This volume consists of one section. The instruction repertoire is divided into groups. Groups 1-18 are hardware instruction groups, and groups 19-25 are pseudo instruction groups. Each group is followed by explanations of new concepts and problems designed to use instructions from the group. #### Volume II This volume consists of two sections. The first section deals with the SCOPE system. It shows how to run jobs under the system and explains new concepts such as overlay processing and library preparation. The second section contains several computer output listings obtained as a result of running the example problems under SCOPE. #### REFERENCES | 3400 SCOPE / COMPASS Reference Manual | Pub. | No. | 60057800 | |---------------------------------------------------|------|-----|----------| | 3400/3600/3800 Instant TAPE SCOPE | Pub. | No. | 60059000 | | 3600 Computer System Reference Manual | Pub. | No. | 60021300 | | 3600 COMPASS Reference Manual | Pub. | No. | 60052500 | | 3600 Instant COMPASS | Pub. | No. | 60056500 | | SCOPE Reference Manual | Pub. | No. | 60053300 | | 3000 Series Peripheral Equipment Reference Manual | Pub. | No. | 60108800 | #### CONTENTS ### VOLUME II # GROUPED INSTRUCTION PROBLEM SOLVING | GROUP 1. FULL WORD TRANSM | <u>MISSION</u> | 1-1 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------------------------------| | <ol> <li>Load A</li> <li>Load Q</li> <li>Load A Complement</li> <li>Load Q Complement</li> <li>Store A</li> <li>Store Q</li> <li>Transmit*</li> </ol> | LDA<br>LDQ<br>LAC<br>LQC<br>STA<br>STQ<br>XMIT | 1-2<br>1-6<br>1-10<br>1-14<br>1-18<br>1-22<br>1-26 | | NEW CONCEPTS OF GROUP 1.<br>PROBLEM UTILIZING INSTRUCT | TIONS FROM GROUP 1 | 1-31<br>1-32 | | GROUP 2. ADDRESS TRANSMISS | SION | 2-1 | | <ol> <li>Load Index Upper</li> <li>Load Index Lower</li> <li>Store Index Upper</li> <li>Store Index Lower</li> <li>Substitute Address Upper</li> <li>Substitute Address Lower</li> <li>Enter Index</li> <li>Enter Q</li> </ol> | | 2-2<br>2-6<br>2-10<br>2-14<br>2-18<br>2-22<br>2-26<br>2-30<br>2-34 | | NEW CONCEPTS OF GROUP 2.<br>PROBLEM UTILIZING INSTRUCT | CIONS FROM GROUP 2 | 2-39<br>2-40 | | GROUP 3. ADDRESS ARITHMET | IC_ | 3-1 | | <ol> <li>Increase A</li> <li>Increase Index</li> </ol> | INA<br>INI | 3-2<br>3-6 | | NEW CONCEPTS OF GROUP 3<br>PROBLEM UTILIZING INSTRUCT | CIONS FROM GROUP 3 | 3-11<br>3-12 | | GROUP 4. INDEXING | | 4-1 | | <ol> <li>Index Skip</li> <li>Index Jump</li> </ol> | ISK<br>IJP | 4-2<br>4-6 | | NEW CONCEPTS OF GROUP 4. PROBLEM UTILIZING INSTRUCT | 'IONS FROM GROUP 4 | 4-11 | <sup>\*</sup> Denotes 48-bit instruction | GROUP 5. FIXED POINT ARITH | <u>METIC</u> | 5-1 | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|----------------------------------------| | <ol> <li>Add</li> <li>Subtract</li> <li>Multiply Integer</li> <li>Divide Integer</li> <li>Multiply Fractional</li> <li>Divide Fractional</li> </ol> | ADD<br>SUB<br>MUI<br>DVI<br>MUF<br>DVF | 5-2<br>5-6<br>5-1<br>5-1<br>5-1<br>5-2 | | NEW CONCEPTS OF GROUP 5<br>PROBLEM UTILIZING INSTRUC | TIONS FROM GROUP 5 | 5-2<br>5-3 | | GROUP 6. REPLACE OPERATION | ONS | 6-1 | | <ol> <li>Replace Add</li> <li>Replace Subtract</li> <li>Replace Add One</li> <li>Replace Subtract One</li> </ol> | RAD<br>RSB<br>RAO<br>RSO | 6 - 2<br>6 - 6<br>6 - 1<br>6 - 1 | | NEW CONCEPTS OF GROUP 6<br>PROBLEM UTILIZING INSTRUC | TIONS FROM GROUP 6 | 6 - 1<br>6 - 2 | | GROUP 7. JUMPS AND STOPS | - | 7-1 | | <ol> <li>Unconditional Stop/Jump</li> <li>Selective Jumps</li> <li>A Jump</li> <li>Q Jump</li> <li>Selective Stops</li> </ol> | SLX<br>SJX<br>AJP<br>QJP<br>SSX | 7-2<br>7-6<br>7-1<br>7-1<br>7-1 | | NEW CONCEPTS OF GROUP 7<br>PROBLEM UTILIZING INSTRUC | TIONS FROM GROUP 7 | 7 - 2<br>7 - 2 | | GROUP 8. RETURN JUMPS AN | D STOPS | 8 - 1 | | <ol> <li>Unconditional Stop/Return Jump</li> <li>Selective Return Jumps</li> <li>A Return Jump</li> <li>Q Return Jump</li> <li>Selective Stop/Return Jumps</li> </ol> | RTJ/SRJ<br>RJX<br>ARJ<br>QRJ<br>SRX | 8-2<br>8-6<br>8-1<br>8-1 | | NEW CONCEPTS OF GROUP 8 PROBLEM UTILIZING INSTRUC | | 8 <b>-</b> 2<br>8 - 2 | | GROUP 9. REGISTER JUMPS | | 9 - 1 | | 1. Register Jump* | RGJP | 9 - 2 | | <ol> <li>Non-zero Bit J</li> <li>Zero Bit Jump</li> </ol> | | 9-6<br>9-10 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|--------------------------------------------------------------------| | NEW CONCEPTS OF O | ROUP 9<br>INSTRUCTIONS FROM GR | OUP 9 9-15<br>9-16 | | GROUP 10. BANK JU | MPS | 10-1 | | <ol> <li>Bank Jump Lov</li> <li>Bank Return Jump</li> </ol> | | 10-2<br>10-6<br>10-10<br>10-14<br>10-18 | | NEW CONCEPTS OF C<br>PROBLEM UTILIZING | ROUP 10<br>INSTRUCTIONS FROM GR | OUP 10 10-23 | | GROUP 11. INTER-R | EGISTER | 11-1 | | <ol> <li>Register Opera</li> <li>Register Swap</li> <li>Register Trans</li> </ol> | RSW | 11-2<br>11-6<br>11-10 | | NEW CONCEPTS OF C | ROUP 11<br>INSTRUCTIONS FROM GR | OUP 11 11-15 | | GROUP 12. SHIFTING | OPERATIONS | 12-1 | | <ol> <li>A Right Shift</li> <li>A Left Shift</li> <li>Q Right Shift</li> <li>Q Left Shift</li> <li>Long Right Shift</li> <li>Long Left Shift</li> <li>Scale A</li> <li>Scale AQ</li> </ol> | | 12-2<br>12-6<br>12-10<br>12-14<br>12-18<br>12-22<br>12-26<br>12-30 | | NEW CONCEPTS OF C | ROUP 12<br>INSTRUCTIONS FROM GR | 12-35<br>OUP 12 12-36 | | GROUP 13. LOGICAL | OPERATIONS | 13-1 | | <ol> <li>Selective Set</li> <li>Selective Clear</li> <li>Selective Community</li> <li>Selective Substitute</li> </ol> | plement SCM | 13-2<br>13-6<br>13-10<br>13-14 | <sup>\*</sup> Denotes 48-bit instruction | 6. | Load Logical<br>Add Logical<br>Subtract Logical<br>Store Logical | LDL<br>ADL<br>SBL<br>STL | 13-18<br>13-22<br>13-26<br>13-30 | |------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----------------------------------------------------------------------------------------------| | | ONCEPTS OF GROUP 13<br>LEM UTILIZING INSTRUCTIONS FI | ROM GROUP 13 | 13-35<br>13-36 | | GROUP | P 14. SINGLE PRECISION FLOAT | NG POINT ARITHMETIC | 14-1 | | 1.<br>2.<br>3.<br>4. | Floating Subtract<br>Floating Multiply | FAD<br>FSB<br>FMU<br>FDV | 14-2<br>14-6<br>14-10<br>14-14 | | | ONCEPTS OF GROUP 14<br>EM UTILIZING INSTRUCTIONS FI | ROM GROUP 14 | 14-19<br>14-24 | | | P 15. SEARCH | .o.w dito of 11 | 15-1 | | 2.<br>3.<br>4.<br>5.<br>6.<br>7.<br>8.<br>9.<br>10.<br>11. | Equality Search Threshold Search Masked Equality Search Masked Threshold Search Search Equality* Search Masked Equality* Search Within Limits* Search Magnitude Within Limits* Locate List Element Upper* Locate List Element Lower* Scan* ONCEPTS OF GROUP 15 EM UTILIZING INSTRUCTIONS FR | LSTU<br>LSTL<br>SCAN | 15-2<br>15-6<br>15-10<br>15-14<br>15-18<br>15-22<br>15-26<br>15-30<br>15-34<br>15-38<br>15-42 | | | 16. STORAGE TEST | | 16-1 | | 1.<br>2. | Storage Skip<br>Storage Shift | SSK<br>SSH | 16-2<br>16-6 | | | ONCEPTS OF GROUP 16<br>EM UTILIZING INSTRUCTIONS FF | ROM GROUP 16 | 16-11<br>16-12 | | GROUP | 17. VARIABLE DATA FIELD TR | ANSMISSION | 17-1 | | 2. | Load Byte* Store Byte* 48-bit instruction | LBYT<br>SBYT | 17-2<br>17-6 | | NEW CONCEPTS OF GROUP 17<br>PROBLEM UTILIZING INSTRUCTIONS FROM GROUP 17 | | 17-11<br>17-13 | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|------------------------------------------------------| | GROUP 18. INPUT/OUTPUT | | 18-1 | | <ol> <li>External Function*</li> <li>Begin Read*</li> <li>Begin Write*</li> <li>Copy Status*</li> <li>Clear Channel*</li> </ol> | CONN<br>EXTF<br>BEGR<br>BEGW<br>COPY<br>CLCH<br>IPA | 18-2<br>18-6<br>18-10<br>18-14<br>18-18<br>18-22 | | NEW CONCEPTS OF GROUP 18<br>PROBLEM UTILIZING INSTRUCTIONS FRO | OM GROUP 18 | 18-31<br>18-36 | | GROUP 19. LOCAL STORAGE ALLOCATI | ON | 19-1 | | <ol> <li>Block Storage Reservation (Starting)</li> <li>Block Storage Reservation (Ending)</li> <li>Octal Data Initialization</li> <li>Decimal Data Initialization</li> <li>Double Precision Data Initialization</li> <li>Binary-Coded-Decimal Data Initialization</li> <li>Type Character Initialization</li> <li>Variable Field Data Initialization</li> </ol> | ) BES<br>OCT<br>DEC | 19-2<br>19-3<br>19-4<br>19-5<br>19-7<br>19-8<br>19-9 | | <ul><li>8. Variable Field Data Initialization</li><li>9. Literals</li></ul> | = MV<br>= S | 19-12 | | NEW CONCEPTS OF GROUP 19<br>PROBLEM UTILIZING INSTRUCTIONS FRO | OM GROUP 19 | 19-15<br>19-16 | | GROUP 20. SUBPROGRAM LINKAGE | | 20-1 | | <ol> <li>Entry</li> <li>External</li> </ol> | ENTRY<br>EXT | 20-2<br>20-3 | | NEW CONCEPTS OF GROUP 20<br>PROBLEM UTILIZING INSTRUCTIONS FR | OM GROUP 20 | 20-4<br>20-12 | | GROUP 21. SPECIAL INSTRUCTIONS | | 21-1 | | <ol> <li>Equivalence</li> <li>Bank</li> <li>Enter Operand Bank</li> <li>Call</li> </ol> | EQU<br>BANK<br>ENQ<br>CALL | 21-2<br>21-3<br>21-4<br>21-5 | <sup>\*</sup> Denotes 48-bit instruction | NEW CONCEPTS OF GROUP 21<br>PROBLEM UTILIZING INSTRUCTIONS | S FROM GROUP 21 | 21-6<br>21-7 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|------------------------------------------------------------------------| | GROUP 22. GLOBAL STORAGE ALLO | OCATION | 22-1 | | <ol> <li>Block</li> <li>Common</li> <li>Originate Relative Counter</li> </ol> | BLOCK<br>COMMON<br>ORGR | 22-2<br>22-3<br>22-4 | | NEW CONCEPTS OF GROUP 22<br>PROBLEM UTILIZING INSTRUCTIONS | S FROM GROUP 22 | 22-5<br>22-8 | | GROUP 23. PROGRAMMER MACROS | _ | 23-1 | | <ol> <li>Macro</li> <li>End Macro</li> </ol> | MACRO<br>ENDM | 23-2<br>23-3 | | NEW CONCEPTS OF GROUP 23<br>PROBLEM UTILIZING INSTRUCTIONS | FROM GROUP 23 | 23-4<br>23-5 | | GROUP 24. ECHO AND IF INSTRUCT | IONS | 24-1 | | <ol> <li>Echo</li> <li>If Non-zero</li> <li>If Zero</li> <li>If Inequalities</li> <li>If Upper</li> <li>If Lower</li> <li>If True</li> <li>If False</li> <li>End If</li> </ol> | ECHO IFN IFZ IF, s IFU IFL IFT, s IFF, s ENDIF | 24-2<br>24-3<br>24-4<br>24-5<br>24-6<br>24-7<br>24-8<br>24-10<br>24-11 | | NEW CONCEPTS OF GROUP 24<br>PROBLEM UTILIZING INSTRUCTIONS | S FROM GROUP 24 | 24-12<br>24-14 | | GROUP 25. LIST CONTROL INSTRUC | CTIONS | 25-1 | | <ol> <li>No List</li> <li>List</li> <li>Space</li> <li>Eject</li> <li>Remark</li> <li>Title</li> <li>Brief</li> <li>Detail</li> </ol> | NOLIST LIST SPACE EJECT REM TITLE BRIEF DETAIL | 25-2<br>25-3<br>25-4<br>25-5<br>25-6<br>25-7<br>25-8<br>25-9 | | NEW CONCEPTS OF GROUP 25<br>PROBLEM UTILIZING INSTRUCTIONS | S FROM GROUP 25 | 25-10<br>25-11 | # GROUP 1 # FULL WORD TRANSMISSION #### GROUP 1 #### FULL WORD TRANSMISSION | 1. | Load A | LDA | |----|-------------------|-------------| | 2. | Load Q | $_{ m LDQ}$ | | 3. | Load A Complement | LAC | | 4. | Load Q Complement | LQC | | | Store A | STA | | 6. | Store Q | STQ | | 7. | Transmit | XMIT | This group of instructions transmits one or more 48-bit words from one location to another. The first two instructions transmit a word from a storage address to a register. They are called LOAD instructions. One storage cycle is required for each. The second two instructions do the same thing; however, the complement of the memory word is transmitted from a storage address to a register. These are called LOAD COMPLEMENT instructions. Again, one storage cycle is required for each. The next two instructions, called the STORE instructions, transmit words from a register to a storage address. One storage cycle is required for each instruction. The last instruction is a memory-to-memory transfer. One or more words may be transferred. Normally, only the destination, not the source, is affected by the transmission. #### The LOAD A Instruction The LOAD A instruction is an instruction that transmits a 48-bit operand from an 18-bit storage address to the A register. One memory reference is made. The operation leaves the contents of the storage address unchanged. The initial contents of the A register are replaced by the transmitted operand. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is transmitted to the A register; i.e., the operand is read from memory, complemented, and then transferred to the A register. If MG is specified by the programmer, the magnitude (absolute value) of the operand is transmitted to the A register; i.e., the operand is read from memory, tested to obtain its absolute value, and then transferred to the A register. Load A from address PRIME. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|----------------------------------------------| | | $L_1D_1A_1$ $P_1R_1I_1M_1E_1$ | 1 | | 1 2 3 4 5 6 7 8 | <br> | 51371381391401411421431441451461471481401401 | #### PROBLEM: Load A from address PRIME modified by Index Register 3. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | $L_1D_1A_1$ , $P_1R_1I_1M_1E_1$ , $3$ | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Load A with the absolute value from address NUMBER. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------------------|-------------------------------------------------------------------------------------------------|----------| | | $L_iD_iA_i$ , $M_iG_i$ , $N_iU_iM_iB_iE_iR_i$ | | | 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10 111 12 13 14 15 16 17 18 19 20 21 22 23 24 25 126 27 128 129 30 131 32 133 134 135 136 137 | | #### PROBLEM: ${\tt Load}\ {\tt A}\ {\tt from}\ {\tt address}\ {\tt NUMBER}\ {\tt from}\ {\tt the}\ {\tt bank}\ {\tt in}\ {\tt which}\ {\tt the}\ {\tt LDA}$ resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|----------| | | $L_{i}D_{i}A_{i}$ $(*)N_{i}U_{i}M_{i}B_{i}E_{i}R_{i}$ | | | 1 12 3 4 5 6 7 8 | 9 10 [11 [12 [13 [14 [15 [16 [17 [18 [19 [20 [21 [22 [23 [24 [25 [26 [27 [28 [29 [30 [31 [32 [33 [34 [35 [35 [35 [35 [35 [35 [35 [35 [35 [35 | | #### The LOAD Q Instruction The LOAD Q instruction is an instruction that transmits a 48-bit operand from an 18-bit storage address to the Q register. One memory reference is made. The operation leaves the contents of the storage address unchanged. The initial contents of the Q register are replaced by the transmitted operand. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is transmitted to the Q register; i.e., the operand is read from memory, complemented, and then transferred to the Q register. If MG is specified by the programmer, the magnitude (absolute value) of the operand is transmitted to the Q register; i.e., the operand is read from memory, tested to obtain its absolute value, and then transferred to the Q register. Load Q from address CONST +5. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|------------------------------------------------------------------------|--------------------------------------------------------------------------| | | LDQ | | | 1 12 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | 33 [34] 35 [36 [37 [38 [39] 40] 4+ [42 ] 43 [44 [45 [46 [47 [48 [49] 50] | #### PROBLEM: Load Q from address CONST modified by Index Registers 2 and 3. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------| | | $L_1D_1Q_1$ $C_1\emptyset_1N_1S_1T_1, 2_1, 3_1$ | | | 1 2 3 4 5 6 7 8 | 9 10[11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 3 | 4[35]36[37]38[39]40[4: 42]43[44]45[46]47[48]49[50] | #### PROBLEM: Load Q with the absolute value from address ROOT. #### SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------|---------------------------------------------------------| | | LIDIQI, MIGI RIPITI | 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 13 14 115 16 117 118 119 220 21 22 23 24 22 3 26 127 28 29 30 131 13: | 2133134135136137138139140141142143144145146147148149150 | #### PROBLEM: Load Q from address CONSTOR from the bank in which CONSTOR resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------|----------------------------------------------| | | $L_1D_1Q_1$ $(\#_1)_1C_1\emptyset_1N_1S_1T_1\emptyset_1R_1$ | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 23 34 35 3 | 6[37]38[39]40[4:[42]43]44]45[46]47[48]49[50] | #### The LOAD A COMPLEMENT Instruction The LOAD A COMPLEMENT instruction is an instruction that transmits the complement of a 48-bit operand from an 18-bit storage address to the A register. One memory reference is made. The operation leaves the contents of the storage address unchanged. The initial contents of the A register are replaced by the transmitted operand. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the complement of the operand is transmitted to the A register. Effectively it would be a LOAD A instruction. If MG is specified by the programmer, the negative value of the operand is transmitted to the A register; i.e., the operand is read from memory, tested to obtain its absolute value, complemented, and then transferred to the A register. The CM and MG modifiers are seldom used for this instruction. Load A with the complement of the operand at address BILKO. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------------------------------|-----------------------------------------------------------------------------------|----------| | -4-4-4-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1- | LAC BILK | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 13 14 115 16 117 118 119 120 221 22 23 24 25 2 3 27 28 29 30 23 1 32 | | #### PROBLEM: Load A with the complement of the operand at address BILKO modified by Index Register 4. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------|-------------------------------------------------| | | LAC | | | 1 2 3 4 5 6 7 8 | 9 10 11 112 113 114 115 116 117 118 119 20 21 122 123 124 125 126 127 128 129 130 131 132 133 134 | 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Load A with the complement of an operand at an address specified in Index Register 5. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------| | | LAC 1 | 1 | | 1 2 3 4 5 6 7 8 | <br> 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | 3914014: 142143144145146147148149150 | #### PROBLEM: Load A with the complement of an operand at address BAKER modified by Index Registers 1 and 2. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------| | <u> </u> | LAC BAKERIZI / 12/2 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 116 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 13 | 18 39 40 4 42 43 44 45 46 47 48 49 50 | #### The LOAD Q COMPLEMENT Instruction The LOAD Q COMPLEMENT instruction is an instruction that transmits the complement of a 48-bit operand from an 18-bit storage address to the Q register. One memory reference is made. The operation leaves the contents of the storage address unchanged. The initial contents of the Q register are replaced by the transmitted operand. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the complement of the operand is transmitted to the Q register. Effectively it would be a LOAD Q instruction. If MG is specified by the programmer, the negative value of the operand is transmitted to the Q register; i.e., the operand is read from memory, tested to obtain its absolute value, complemented, and then transferred to the Q register. The CM and MG modifiers are seldom used for this instruction. Load ${\bf Q}$ with the complement of the operand at an address specified by Index Register 4. #### SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------------------------|----------------------------| | | LQC 4 | | | | | <del></del> | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 21 122 23 124 125 126 127 128 129 130 131 132 133 134 135 136 137 | 38139140141142143144445144 | #### PROBLEM: Load ${\bf Q}$ with the complement of an operand at address HOMER, but indirectly. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------|------------------------------------------------| | | LIQIC, HIPMIE, RISIT, | 1 | | 1 2 3 4 5 6 7 8 | <br> 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 31 | 5136137138139140141142143144145146147148149150 | #### PROBLEM: Load Q with the complement of an operand at address SNODGRASS from the bank in which the LQC resides. #### SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------| | | $L_{1}Q_{1}C_{1}$ , $(i*_{1})_{1}S_{1}N_{1}\phi_{1}P_{1}G_{1}R_{1}A_{1}S_{1}S_{1}$ | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 112 113 114 115 116 117 118 119 20 21 122 23 24 125 26 127 128 129 130 131 132 133 134 1 | 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Load ${\bf Q}$ with the complement of an operand at address SNODGRASS-3. | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |---------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------------------| | | $L_{1}Q_{1}C_{1}$ $S_{1}N_{1}O_{1}C_{1}G_{1}R_{1}A_{1}S_{1}S_{1}-3$ | <u> </u> | | 1 2 3 4 5 6 7 | | 135 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### The STORE A Instruction The STORE A instruction is an instruction that transmits a 48-bit operand from the A register to an 18-bit storage address. One memory reference is made. The operation leaves the contents of the A register unchanged unless the modifier CL is specified (see below). The contents of A replace the contents of the storage address. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = m + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the contents of A is transmitted to the storage address. If MG is specified by the programmer, the magnitude (absolute value) of the contents of A is transmitted to the storage address. If CL is specified by the programmer, the contents of A are cleared <u>after</u> the operand has been transmitted to the storage address. Store A at five memory locations forward. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------|----------| | | S.T.A. *+5 | | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12 [13 [14 [15 [16 [17 [18 ]19 [20 [21 [22 [23 [24 [25 [26 [27 [28 [29 ]30 [ | <br> | #### PROBLEM: Store A at address COUNTER and then clear A. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------|--------------------------------| | | $S_iT_iA_{i,j}C_iL_{i,j}$ $C_i\phi_iU_iN_iT_iF_iR_{i,j}$ | 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10[11] 12 [13] 14 [15] 16 [17] 18 [19] 20[21] 22[23] 24[25[26] 27[28] 29] 30[31] 32[33] 34[35] 36[37] 38[37] | 041 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Store the absolute value of A at an address specified in Index Register 1. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | $S_1T_1A_1 = M_1G_1$ | | | 1 2 3 4 5 6 7 8 | 9 10[11 [12[13]14]15]16[17]18 [19 [20[21]22[23[24]25]26[27]28[29]30[31]32[33]34[35] | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Store A indirectly at SAVE. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | _ | S.T.A. S.A.V.E. 7 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12 [13 [14 [15 [16 [17 [16 [19 [20 [21 [22 [23 [24 [25 [26 [27 [28 [29 [30 [31 [32 [33 [34 [35 ]36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [35 [36 [36 [35 [36 [36 [36 [36 [36 [36 [36 [36 [36 [36 | | #### The STORE Q Instruction The STORE Q instruction is an instruction that transmits a 48-bit operand from the Q register to an 18-bit storage address. One memory reference is made. The operation leaves the contents of the Q register unchanged unless the modifier CL is specified (see below). The contents of Q replace the contents of the storage address. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the contents of Q is transmitted to the storage address. If MG is specified by the programmer, the magnitude (absolute value) of the contents of Q is transmitted to the storage address. If CL is specified by the programmer, the contents of Q are cleared <u>after</u> the operand has been transmitted to the storage address. Store Q at address SMOKEY modified by Index Registers 2 and 3. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | S,T,Q, S,M,Ø,K,E,Y,2,2,2,3 | | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 | 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 22 9 30 23 1 32 23 3 3 4 35 | 36 37 38 39 40 41 42 43 44 45 45 47 48 49 40 | #### PROBLEM: Store the complement of Q at address BEAR. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|----------------------------------------------------------------| | | $STQ_{2}CM$ | | | 1 2 3 4 5 6 7 8 | | 136137 38139 40141 42143 44145 45145 47148 49150 | #### PROBLEM: Store Q at one memory location forward of the address specified in Index Register 3. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------| | | 5,70, 1,2,3 | 1 | | 1 2 3 4 5 6 7 8 | <br> 9 10 11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 513613713813914014114314314 | #### PROBLEM: Store Q at an address which is five memory locations backward from an address specified in Index Register 1. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------|----------| | | S.T.Q | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 110 119 120 21 22 23 24 25 26 27 28 29 30 31 32 33 34 3 | | #### The TRANSMIT Instruction The TRANSMIT instruction transmits a word or a group of words from one area of memory to another area of memory. The operation leaves the contents of the source area unchanged. If CM is specified by the programmer, the complement of the source is transmitted to the destination address. If MK is specified by the programmer, the source is masked with the contents of Q before being transmitted to the destination address. If PC is specified by the programmer, the source is incremented by the contents of A in fixed point format before being transmitted to the destination address. If AUG is not specified by the programmer, only one word is transmitted. The source address is (a) m and the destination address is (i) n. The index registers are not significant. If AUG is specified by the programmer, five index registers must be set up before executing this instruction. $(B^1)$ = number of words to transmit (B<sup>2</sup>) = source address modifier (normally zero to start) $(B^3)$ = incrementer for $B^2$ (normally 1 for sequential words) (B<sup>4</sup>) = destination address modifier (normally zero to start) (B<sup>5</sup>) = incrementer for B<sup>4</sup> (normally 1 for sequential words) Transmit an operand from Bank 2 address HOKEY to Bank 3 address POKEY. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------| | | X,M,I,T, (,2,),H,Ø,K,E,Y,,,(,3,),P,Ø,I | Κ <sub>Ι</sub> Ε, <b>Υ</b> , , , , , , , , , , , , , , , , , , , | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12 [13 [14 [15 [16 [17 [18 [19 [20]21]25]25]25]25]26 127]28 [29 [20]31]32[33]3 | 1 | PROBLEM: Given: (Q) = +77B Extract the lowest six bits from Bank 5 address MURTLE and place the result in Bank 6 address TURTLE. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------|-----------------------------------| | | X,M,I,T,,,M,K, , , ((5)),M,U,R,T,L,E,,,((6)),T,U,R,T,L,E, | 1 | | 1 ] 2 ] 3 4 5 6 7 8 | 9 (0[11 [12]13]14]15[16]17[18]19[20[21]22[23]24[25[26]27[28]29[30[31]32[33]34[35]36[37]38[39] | 401411421431441451461471481491501 | PROBLEM: Given: $(B^1) = 100$ , $(B^2) = 0$ , $(B^3) = 1$ , $(B^4) = 0$ , $(B^5) = 1$ Transmit the 100 words from Bank 1 address BLOCK to Bank 1 address TABLE. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------|-------------------------------------------------------------------------------------------------------------------|------------------------------------------| | | XIMITI, AUG , (1) BLOCK, (1) TAB | LE I I I I I I I I I I I I I I I I I I I | | 1 12 13 14 15 16 17 11 | 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | 1 | PROBLEM: Given: $(B^1) = 10$ , $(B^2) = CARD$ , $(B^3) = 1$ , $(B^4) = ZILCH$ , $(B^5) = 1$ Transmit the 10 words starting at CARD to the 10 locations starting with ZILCH. Both are in Bank 3. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------|----------------------------------------------------------------------------------------------------------|----------| | | XMITT , A.U.G. (3) (3) | | | 1 12 13 14 15 16 17 18 | 9 10 [11 [12 [13 [14 [15 [16 [17 [16 [19 [20 [21 [22 [23 [24 [25 [27 [28 [29 [20 [31 [32 [33 [34 ]35 [36 | <br> | # NEW CONCEPTS OF GROUP 1 The first group contains relatively few new concepts. 48-bit words are transmitted from a source to a destination. The source always remains as it was except on the STA and STQ instructions when <u>CL</u> is specified as a modifier. In this case the register is cleared after the transmission takes place. Operands can be complemented as they are transferred. The 1's complement format is used. This algebraically changes the sign of the operand. The magnitude (absolute value) can also be transferred. In this case a check is made on the sign of the operand. If it is negative, it is complemented during transmission. If it is positive, it is a normal transmission. In either case the positive form is transferred. # Problem 1: A 10,000 word table in memory starting at address TAB contains operands both positive and negative. Replace every positive operand with zero and every negative operand with its absolute value. Problem 1 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------|-----------------------------------------------------------------------------------------------------|------------------------------------------------| | 1 1 2 1 3 1 4 1 3 1 4 1 2 1 8 | • <b>*</b> | [26] [21] [27] [27] [26] [25] [26] [27] [28] [28] [28] [31] [32] [35] [34] [35] [34] [37] [38] [37] | <br> | | | EDENT | T.E.S.T | | | | ENTRY | TEST | <u> </u> | | TEST | BSS. | 1 | | | | ENQ | 0 | <u> </u> | | | ENI | <i>a, 1</i> | !<br>L., ., ., ., ., ., ., ., ., ., ., ., ., . | | NEXT | | T.A.B., 1 | | | | AJP, MI | MINUS | POS OR NEG | | PLUS | STQ | TAB, / | Pas | | | иЈР | INCR | !<br>L | | MINUS | STA, CM | TAB, I | WEG | | INCR | IsK | 9999,1 | 1 | | | 545 | WEXT | | | | 5LJ | TEST | 1<br>1 | | | ENO | | | Somewhere within this subprogram would also be included the symbol TAB in the location field with a declaration of the prestored data or area reserved. # Student Problem 1A: Using the XMIT instruction, transmit 10 words starting at address CARD to an area starting at address CARD1. As each word is transferred, extract the lower 9 bits (zero out the upper 39 bits) of each word. Flowchart: Problem 1A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------|----------| | 113131413141714 | ալոլայայա <u>յա</u> յայայայա առ <sub>12</sub> 1 | 22 28 24 25 36 27 28 27 28 27 36 31 32 33 34 33 34 37 38 37 40 | <br> | | | | | | | | + | | | | | <del> </del> | <u> </u> | | | <del></del> | <del> </del> | | | | | | <u> </u> | <u></u> | | | | | | | | | | | | | | | | | | <u> </u> | <u> </u> | | | | <u> </u> | | | | <del></del> | +++++++++++++++++++++++++++++++++++++++ | <u>i </u> | | | | <del> </del> | | | | | <del> </del> | <u> </u> | | # GROUP 2 ADDRESS TRANSMISSION # GROUP 2 #### ADDRESS TRANSMISSION | 1. | Load Index Upper | LIU | |----|-------------------------------|----------------------| | 2. | | LIL | | 3. | Store Index Upper | SIU | | 4. | | $\operatorname{SIL}$ | | 5. | in a contract tract con opper | SAU | | | Substitute Address Lower | SAL | | | Enter Index | $\mathbf{ENI}$ | | | Enter A | ENA | | 9. | Enter Q | ENQ | This group of instructions transmits 15-bit quantities that may be either addresses or operands. The first two instructions transmit a portion of a memory word to an index register, requiring one storage cycle. The second two instructions transmit the contents of an index register to a portion of a memory word at a storage address, leaving the rest of the memory word untouched. One storage cycle is required. The next two instructions transmit the lower address portion of A to a portion of a memory word, leaving the rest of the memory word untouched. Again, one storage cycle is required. The ENTER instructions transmit a 15-bit quantity to a register. No storage cycle is required for these instructions. #### The LOAD INDEX UPPER Instruction The LOAD INDEX UPPER instruction is an instruction that transmits a 15-bit quantity from the upper address portion of a memory word to an index register specified by index designator b. One memory reference is made. The operation leaves the contents of the storage address unchanged. The 15-bit upper address portion of the memory word replaces the contents of the index register. The memory word is found at an 18-bit storage address composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = m + (V^V)$ . If the bank term is missing, the current operand bank setting is assumed. The v index designator allows for relative addressing. If it is not used, direct addressing is implied. If CM is specified by the programmer, the complement of the upper address portion of the memory word is transmitted to the index register. If MG is specified by the programmer, the magnitude (absolute value) of the upper address portion of the memory word is transmitted to the index register. Load Index Register 1 with the upper address portion of the word at address MORTIMER. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | | $L_{IU}$ $M_{I}$ $M_{$ | | | 1 2 3 4 5 6 7 8 | 9 10 11: 112 113 114 115 116 117 118 119 120 21 122 23 24 25 26 27 28 29 30 31 32 33 34 3 | 5[36[37[38]39]40[4:]42]43]44[45]46[47]48[49]50[ | #### PROBLEM: Load Index Register 6 with the upper address portion of the word at address SNERD modified by Index Register 5. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | L, I, U, S, N, E, R, D, 2, 6, 2, 5 | | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 (0]11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 2 | 37 (38 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: Load Index Register 2 with the upper address portion of the word at the address specified by Index Register 4. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------| | | L,I,U, 1,1,2,3,4,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | }<br>33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: Load Index Register 5 with the upper address portion of the word at an address four memory locations backward from this instruction. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------|------------------------------------------------------| | | LIU *-4,55 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 3 | 134 35 36 37 38 39 40 4: 42 43 44 45 46 47 48:49 50: | #### The LOAD INDEX LOWER Instruction The LOAD INDEX LOWER instruction is an instruction that transmits a 15-bit quantity from the lower address portion of a memory word to an index register specified by index designator <u>b</u>. One memory reference is made. The operation leaves the contents of the storage address unchanged. The 15-bit lower address portion of the memory word replaces the contents of the index register. The memory word is found at an 18-bit storage address composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (V^V)$ . If the bank term is missing, the current operand bank setting is assumed. The v index designator allows for relative addressing. If it is not used, direct addressing is implied. If CM is specified by the programmer, the complement of the lower address portion of the memory word is transmitted to the index register. If MG is specified by the programmer, the magnitude (absolute value) of the lower address portion of the memory word is transmitted to the index register. Load Index Register 1 with the lower address portion of the memory word at address CHAREAD. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------|-----------------------------------------------------| | | $L_{1}I_{1}L_{1}$ $C_{1}H_{1}A_{1}R_{1}E_{1}A_{1}D_{1}$ | <u> </u> | | 1 2 3 4 5 6 7 8 | <br> | 513613713813914014114214314414514614714614714614714 | # PROBLEM: Load Index Register 2 with the lower address portion of the memory word at address CARACDEF + 3. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|----------------------------------------------| | | LIL CARACDEF+312 | | | 1 2 3 4 5 6 7 8 | | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Load Index Register 3 with the lower address portion of the memory word at address CALFIDNT modified by Index Register 4. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------| | | LIL CALFIDNT, 3124 | | | 1 2 3 4 5 6 7 8 | 9 10 [11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 31 | 6137 38 39 40 41 42 43 44 45 45 45 45 45 45 | # PROBLEM: Load Index Register 5 with the lower address portion of the memory word at an address specified in Index Register 6. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|-----------------------------------------------------------------------------------------------|---------------| | | L.I.L. 1915,916 | ;<br><u> </u> | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 130 31 132 33 134 35 136 137 13 | 1 | # The STORE INDEX UPPER Instruction The STORE INDEX UPPER instruction is an instruction that transmits a 15-bit quantity from an index register specified by index designator $\underline{b}$ to the upper address portion of a memory word. One memory reference is made. The operation leaves the contents of the index register unchanged. The 15-bit quantity of the index register replaces the upper address portion of the memory word. The rest of the memory word is unchanged. The memory word is found at an 18-bit storage address composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (V^V)$ . If the bank term is missing, the current operand bank setting is assumed. The v index designator allows for relative addressing. If it is not used, direct addressing is implied. Store Index Register 1 in the upper address portion of the memory word at address SAM. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |---------------|-------------------------------------------------------------------------------------------------------------------------|----------| | | $S_{1}I_{1}U_{1}$ $S_{1}A_{1}M_{1}$ , $S_{1}A_{1}M_{2}$ | | | 1121314151617 | [8 9 10 11 112 13 114 115 116 [17] 18 119 [20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 3 | | #### PROBLEM: Store Index Register 2 in the upper address portion of the memory word in Bank 3 address TOM. #### SOLUTION: | LOCN | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|---|-------------------------------------------------|------------------------------|-------------------------------------------------------------------------| | | | SILU | (3) TØM | | | 1 2 3 4 5 6 7 8 | 9 | 10 11 12 13 14 15 16 17 18 19 | 20 2 22 23 24 25 26 27 28 2 | <br> 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Store Index Register 3 in the upper address portion of the memory word at address SAVE + 4. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------| | | S.I.U. | | | 1 2 3 4 5 6 7 8 | 9 10 111 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 3 | 351361371381391401411421431441451461471481491501 | # PROBLEM: Store Index Register 4 in the upper address portion of the memory word at address JOE in the bank where JOE resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------|-------------------------------------------------------------------------------------|----------| | | SITU (\$) JØE, 4 | 1 | | 1 | 9 10 111 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | | # The STORE INDEX LOWER Instruction The STORE INDEX LOWER instruction is an instruction that transmits a 15-bit quantity from an index register specified by index designator $\underline{b}$ to the lower address portion of a memory word. One memory reference is made. The operation leaves the contents of the index register unchanged. The 15-bit quantity of the index register replaces the lower address portion of the memory word. The rest of the memory word is unchanged. The memory word is found at an 18-bit storage address composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M}$ = $\underline{m}$ + ( $V^V$ ). If the bank term is missing, the current operand bank setting is assumed. The $\underline{v}$ index designator allows for relative addressing. If it is not used, direct addressing is implied. Store Index Register 1 in the lower address portion of the memory word at address SAVE. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|--------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------| | | SIL | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | 4 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: Store Index Register 2 in the lower address portion of the memory word at an address two memory locations forward of address BILL. # SOLUTION: | LOCN | | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---|----------------------------------------------------------------------------------------------|----------| | | | $S_{1}I_{L_{1}}$ | <u> </u> | | 1 2 3 4 5 6 7 8 | 9 | 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | <br> | # PROBLEM: Store Index Register 3 in the lower address portion of the memory word at an address specified in Index Register 5. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------|----------| | | S, T, L, , , , , , , 3, 3, 5, , , , , , , , , , | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | | # PROBLEM: Store Index Register 4 in the lower address portion of the memory word at address JAKE in the bank in which the SIL resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------|----------| | | S.I.L. (*) JAKENY | | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12 [13 14 ] 15 [16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 33 | 1 | #### The SUBSTITUTE ADDRESS UPPER Instruction The SUBSTITUTE ADDRESS UPPER instruction is an instruction that transmits a 15-bit quantity from the lower address portion of the A register to the upper address portion of a memory word. One memory reference is made. The operation leaves the contents of the A register unchanged. The 15-bit lower address portion of the A register replaces the upper address portion of the memory word. The rest of the memory word is unchanged. The memory word is found at an 18-bit storage address composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = m + (\underline{B}^b) + (\underline{V}^V)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the lower address portion of the A register is transmitted to the upper address portion of the memory word. If MG is specified by the programmer, the magnitude (absolute value) of the lower address portion of the A register is transmitted to the upper address portion of the memory word. Store the lower address portion of A in the upper address portion of TEMP. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | S.A.U. T.EMP | | | 1 [2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 3 | 7 38 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: Store the lower address portion of A in the upper address portion of TEMP modified by Index Register 4. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------|------------------------------------------------| | | SAU TEMPOH | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 112 113 114 115 116 117 118 119 20 [21 22 23 24 25 26 27 28 29 30 31 32 33 34 3 | 5 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Store the lower address portion of A in the upper address portion of an address specified in Index Register 5. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------|----------| | 111111 | S <sub>1</sub> A <sub>2</sub> U <sub>1</sub> 1 2 5 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 13 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 | | #### PROBLEM: Store the lower address portion of A in the upper address portion of address SLOJOE in Bank 1. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------------------------------|--------------------------------------| | | SAU $(1)SLØJØE$ | 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 112 13 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 1 | 3914014/1421431441451461471481491501 | #### The SUBSTITUTE ADDRESS LOWER Instruction The SUBSTITUTE ADDRESS LOWER instruction is an instruction that transmits a 15-bit quantity from the lower address portion of the A register to the lower address portion of a memory word. One memory reference is made. The operation leaves the contents of the A register unchanged. The 15-bit lower address portion of the A register replaces the lower address portion of the memory word. The rest of the memory word is unchanged. The memory word is found at an 18-bit storage address composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = m + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the lower address portion of the A register is transmitted to the lower address portion of the memory word. If MG is specified by the programmer, the magnitude (absolute value) of the lower address portion of the A register is transmitted to the lower address portion of the memory word. PROBLEM: Store the lower address portion of A in the lower address portion # SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|---------------------------------------| | | SAL | | | 1 2 3 4 5 6 7 8 | <br> | 8 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Store the lower address portion of A in the lower address portion of PETE-1 modified by Index Register 3. # SOLUTION: | LOCN | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|---|----------------------|---------------|---------------------------------------------------------------------| | | | SAL | PETE-1,3 | | | 1 2 3 4 5 6 7 8 | 9 | | 1 | 9 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Store the lower address portion of A in the lower address portion of TOM in the bank where TOM resides. #### SOLUTION: | LOCN | OPERATION, MODIFIERS A | DDRESS FIELD | COMMENTS | |-----------------|-------------------------------------------|------------------------------------------------|---------------------------------------------------------------------| | | SAL | t) Tom | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12]13]14]15 [16]17 [18]19 [20]2 | 1 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 57 38 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: Store the lower address portion of A in the lower address portion of an address that is three memory locations relatively forward. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------| | | S.A.L. *+3 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 1 | 3914014 1421414414414414414414414414414414414414 | # The ENTER INDEX Instruction The ENTER INDEX instruction is an instruction that transmits a 15-bit quantity $\underline{Y}$ , where $Y = y + (V^V)$ , into an index register specified by the index designator $\underline{b}$ . No memory reference is made. If the bank term $\underline{a}$ (within parentheses) is missing, the current operand bank setting remains. If the bank term $\underline{a}$ is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. PROBLEM: Enter Index Register 1 with zero. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------|-------------------------------------| | | ENI | | | 1 1 2 1 3 1 4 5 6 7 8 | 9 10[11][2][3][4][5][6][7][6][9][20[2][22[23][24][25][26][27][20[29][30][31][32][33][34][35][36][37][36] | 39140141142143144145146147148149160 | ## PROBLEM: Enter Index Register 2 with minus zero (all 7's). #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------| | | $E_{N,T_{\perp}}$ | | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Enter Index Register 3 with an octal 77. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | 11111 | ENI | 1<br>1 | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12 [13 [14 [15 [16 [17 [18 [19 [20 [21 [22 [23 [24 [25 [26 [27 [28 [29 [30 [31 [32 [33 ] | 34) 35 136 (37 138 130 100 14 14 14 14 14 14 14 14 14 14 14 14 14 | #### PROBLEM: Enter Index Register 4 with address SNOPS. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------|----------------------------------------------| | | ENIT SINDPS 14 | i<br>i | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 6 | a notni tistis lietis lietistie liatsotsitssitssitselssitselssitselssitsota isstaalaeta | 36 37 38 39 40 4: 42 43 44 45 46 47 48 49 50 | #### The ENTER A Instruction The ENTER A instruction is an instruction that transmits a 15-bit quantity $\underline{Y}$ , where $Y = y + (B^b) + (V^V)$ , into the A register. No memory reference is made. The 15-bit quantity is transmitted right-justified into the A register with the sign bit extended automatically through the rest of A. If the bank term $\underline{a}$ (within parentheses) is missing, the current operand bank setting remains. If the bank term $\underline{a}$ is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. If CM is specified by the programmer, the complement of the quantity Y is transmitted to the A register. Enter A with zero. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|-----------------------------------------| | | E.N.A. | 1 | | 1 2 3 4 5 6 7 8 | <br> | 7 38 39 40 4 42 43 44 45 46 47 40 40 40 | ## PROBLEM: Enter A with the contents of Index Register 1. #### SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | ENA 212 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 3 | 7 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Enter A with -50. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------| | | E.N.A50 | 1 | | 1 2 3 4 5 6 7 8 | <br> 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | 33134135136137138139140141142143144145146147148149150 | #### PROBLEM: Enter A with address POPS. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------| | | $E_{N,A}$ $P_{S}$ | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10 111 12 13 14 15 16 17 10 19 20 21 22 23 24 25 26 27 (20 22 93 03) 132 33 33 43 | 51361371381391401411421431441451451451451491501 | ## The ENTER Q Instruction The ENTER Q instruction is an instruction that transmits a 15-bit quantity $\underline{Y}$ , where $Y = y + (B^b) + (V^V)$ , into the Q register. No memory reference is made. The 15-bit quantity Y is transmitted right-justified into the Q register with the sign bit extended automatically through the rest of Q. If the bank term $\underline{a}$ (within parentheses) is missing, the current operand bank setting remains. If the bank term $\underline{a}$ is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. If CM is specified by the programmer, the complement of the quantity Y is transmitted to the Q register. Enter Q with five less than the contents of Index Register 1. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------|----------| | | ENQ -521 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | <br> | ## PROBLEM: Enter Q with -35 octal. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------| | | E.N.Q35B | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 31 | 6 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Enter Q with the sum of Index Registers 1 and 2. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------| | | ENQ 122 | | | 1 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 3 | 7 138 139 40 41 42 43 44 45 45 47 48 49 50 | #### PROBLEM: Enter Q with address SAM modified by Index Register 3. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------| | <u> </u> | $E_{N,Q}$ $S_{P,M_{12},3}$ | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 3 | <br> | #### NEW CONCEPTS OF GROUP 2 The instructions in this group are much like those in Group 1. Here, only 15 bits are transferred, and these are usually addresses. For the first seven instructions the source and destination are 15 bits each so that it is just a matter of transmission. For the last two instructions (ENA and ENQ) the source is 15 bits, but the destination is 48 bits. In this case the entire register is cleared. The 15 bits are then entered into the lowest part of the register (right justified) and the upper bits are a repetition of bit 14. The symbol \*\* (double asterisk) is introduced here. This symbol prestores a 15 bit address of all 7's. It represents a "dummy" address that is to be replaced by an actual address during the execution of the program. ## Problem 2: Write a subprogram that will transfer 48-bit words from one area of memory to another. As the subprogram is entered, the initial address is in $\underline{A}$ lower, the terminal address is in $\underline{A}$ upper, and the number of words is in $\underline{Q}$ lower. Problem 2 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIE | ERS ADDRESS FIELD | COMMENTS | |----------------------------------------|-----------------------------------------|------------------------------------------------------------------------------|------------------| | 1 12 12 4 5 14 7 18 | 9 10 1 2 3 12 13 1 24 1 25 14 1 27 14 1 | 10 40 43 177 31 150 175 186 177 178 178 188 11 172 183 184 185 184 137 188 | | | | IDENT | TRANSFER | | | | ENTRY | TRANSFER | | | TEMP | BSS. | 12 | | | TRANSFER | BSS | 2 | | | | SAU. | TRANSMIT | INITIAL ADDRESS | | _i _ i _ i _ i _ i _ i _ i _ i _ i _ i | ARS | \$4 | | | | SAL | TRANSMIT | TERMINAL ADDRESS | | | 570 | TEMP | | | | LIL | TEMP, 1 | WARD COUNT | | CHECKCNT | IJP | TRANSMIT, 1 | | | | 545 | TRANSFER | | | TRANSMIT | L.DA | <b>*</b> *,1 | | | | BTA | **,1 | | | 1.1.1.1.1.1.1.1.1. | SLJ | CHECKENT | | | | END | <br> | | | | | <br> - | <u>.</u> | | | | | | ## Student Problem 2A: Write a subprogram that will solve problem 2, but use the XMIT instruction. Flowchart: # Problem 2A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 12 12 14 14 17 14 | 9 18 5 7 1 1 3 7 1 3 7 1 4 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 5 7 1 | <br> | | | | | | 4 1 1 1 1 4 | | <u> </u> | | | | | | | | | | | | | | | <del> </del> | <u> </u> | | | | | | | | <u></u> | | | | I and the second | | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | <u> </u> | <u> </u> | | | <del></del> | <u> </u> | | | <del>- </del> | <u> </u> | | | | | | | | | | | | <u> </u> | ## GROUP 3 ## ADDRESS ARITHMETIC ## GROUP 3 ## ADDRESS ARITHMETIC INA Increase A Increase Index INI This group of instructions performs an addition on the contents of A or the contents of an index register. No storage cycle is required. #### The INCREASE A Instruction The INCREASE A instruction is an instruction that adds a 15-bit quantity $\underline{Y}$ , where $Y = y + (B^b) + (V^v)$ , to the contents of A. The sign of Y is extended to 48 bits before the addition takes place. No memory reference is made. If the bank term $\underline{a}$ (within parentheses) is missing, the current operand bank setting remains. If the bank term $\underline{a}$ is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. If CM is specified by the programmer, the complement of the 15-bit quantity is added to the contents of A. Increase the contents of A by two. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|-----------------------------------------| | | INA 2 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | | | ## PROBLEM: Increase the contents of A by the contents of Index Register 1. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | I.N.A. | | | 1 2 3 4 5 6 7 8 | 9 10[11 [12]13]14]15[16]17[18]19[20]21[22]23]24[25]26[27]28[29]30[31]32[33]34]35] | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Decrement the contents of A by one. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------|----------| | | I.N.A. | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 136 137 138 | 13914014 | #### PROBLEM: Increase the contents of A by 77 octal. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------|------------------------------------------------| | | I.N.A. 7.7.8 | 1 | | 1 2 3 4 5 6 7 8 | <br> | 5 36 37 38 39 40 4: 42 43 44 45 46 47 48 49 50 | ### The INCREASE INDEX Instruction The INCREASE INDEX instruction is an instruction that adds a 15-bit quantity $\underline{Y}$ , where $Y = y + (V^V)$ , to the contents of an index register specified by index designator $\underline{b}$ . No memory reference is made. If the bank term $\underline{a}$ (within parentheses) is missing, the current operand bank setting remains. If the bank term $\underline{a}$ is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. Increase the contents of Index Register 1 by one. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------| | | | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | 1391401411421431441451451471491491501 | ## PROBLEM: Decrease the contents of Index Register 2 by one. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------| | | I_N_I | | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12]13]14 [15]16 [17]18 [19]20[21[22]23]24[25]26[27]28[29]30[31[32]33]34[35]36[37]3 | 38 39 40 40 42 43 44 45 46 47 49 49 50 | #### PROBLEM: Subtract 33B from the contents of Index Register 3. ### SOLUTION: | LOCN | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|---|-------------------------------------------------|----------------------------|---------------------------------------------------------------------| | | L | I.N.I. | -33B,3 | | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 | 10 (1 12 13 14 15 16 17 18 19 | 20 21 22 23 24 25 26 27 28 | [29]30[31]32[33]34]35]36]37]38]39]40]4];42]43]44]45]46]47]48]49]50] | #### PROBLEM: Increase the contents of Index Register 4 by SAM. | LOCN | | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |---------------------|---|--------------------------------------------------------------------------------------------------------|-----------------------------------------------------| | | | INI | 1 | | 1 2 3 3 4 5 5 6 7 8 | 9 | 10 [11 [12] 13 [14] 15 [16 [17] 18 [19 [20] 21 [22] 23 [24] 25 [26 [27] 28 [29] 30 [31 [32] 33 [34] 35 | 136137138138148148148148148148148148148148148148148 | ## NEW CONCEPTS OF GROUP 3 This group consists of fast arithmetic instructions that add positive or negative numbers to the A or index registers. The arithmetic is 1's complement. Since the number added to the register is only 15 bits, the number added is limited to $\pm 16,383$ . You can INA 5, INA -329, but not INA 543216. For this, you would have to ADD the quantity where the quantity resides in memory. Another new concept introduced at this time is the suffixing a number with the letter $\underline{B}$ . Any number suffixed with a $\underline{B}$ is assumed octal. Examples are: 13B, -246B, and 346715B. If no $\underline{B}$ suffixes the number, the number is assumed decimal. Examples are: 59, 63, and -3456. 1348B is illegal. ## Problem 3: Numerous files containing BCD characters have been read into core starting at address BUF. An end-of-file in core is signified by 17B. Write a subprogram that will search for the first end-of-file. When it is found, load the word that contains the end-of-file into A and exit. ## Flowchart: Problem 3 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 . 1 . 2 : 4 5 4 : 7 8 | | 10 27 27 27 28 28 28 27 28 28 | <br> | | | TOENT | FILE. | | | | ENTRY | FILE | | | FILE | BSS | 1 | | | | ENI | 0,1 | ADDRESS COUNTER | | <u> </u> | | 0,2 | · · · · · · · · · · · · · · · · · · · | | WEXTWARD | LDQ | B4F, 1 | <u> </u> | | VEXTCHAR | ENA | 0 | | | | 115 | 6 | 1 | | | INA | -17B | La de la companya del companya de la companya del companya de la c | | | AJP, ZR | FOUND | 14 | | | Isk' | 7,2 | LAST, CHARACTER? | | | | WEXTCHAR | WE and some city top | | | INI | 12.3.1 | YES, BUMP ADDRESS COUNTER | | | 545 | NEXTWORD | | | FOUND. | | 84F-22 | <u> </u> | | | 54 | FILE | <u> </u> | | <u> </u> | ENO | <u> </u> | <u> </u> | | | 4 | <u> </u> | <u> </u> | ## Student Problem 3A: Assume 1000 words of BCD characters with numerous end-of-files (17B) in memory starting at address COMPILE Count the number of end-of-files and store it at address FILE. Flowchart: Problem 3A could be solved by coding in the following manner: | | 1 | | | |-------|--------------|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | ! | | | | | <u> </u> | | | | والمراجع | 4 | | | إخلنتنت | | | | | i | | | | | <del></del> | <u> </u> | | | | | <u> </u> | I and the second | | 1 1 1 | į | | 1 | | 1 | i | | | | 11 | | | | | | <del></del> | • | 1 | | | 1 | <u> </u> | | | !! | 1 | | <u> </u> | | | <del> </del> | | ! | | | | | | | | | | ر بن المراجع ا<br>المراجع المراجع | | 1 1 | | | | | | | | The state of s | GROUP 4 INDEXING #### GROUP 4 #### INDEXING Index Skip Index Jump ISK IJP This group of instructions tests the contents of an index register for being a predetermined value. If it is this value, the program continues. If it is not this value, the contents of the index register are automatically incremented or decremented by one depending on the instruction. These instructions serve a two-fold purpose. First, they can be used as loop counters. Second, the same index register can be used as a modifier each time the loop is entered. In this way a programmer can process a table in the forward or backward direction. #### The INDEX SKIP Instruction The INDEX SKIP instruction is an instruction that compares the quantity y with the contents of an index register specified by the index designator $\underline{b}$ . If the two quantities are equal, a full exit is taken with the contents of the index register being cleared. If the two quantities are not equal, a half exit is taken with the contents of the index register incremented by one. Because of the ability of this instruction to half exit or full exit, the COMPASS assembler will automatically force this instruction to the upper position of a memory word. It would have no meaning if it were assembled in the lower position of the memory word. For this reason the programmer should not use the bank term <u>a</u> (within parentheses) or the v index designator, because by doing so, the assembler must force the instruction lower which defeats its purpose. Examine the contents of Index Register 1 for being equal to 100. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------|---------------------------------------------------| | | I,S,K, 1,0,0,1 | | | 1 2 3 4 5 6 7 8 | <br> | <br> 36 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Examine the contents of Index Register 2 for being equal to 1000 octal #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|----------| | | ISK 1000B 2 | | | 1 2 3 4 5 6 7 8 | | <br> | ## PROBLEM: Examine the contents of Index Register 3 for being equal to 16000. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------| | | I,S,K, , , , , , , , , , , , , , , , , , | 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | 39 40 4 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Examine the contents of Index Register 4 for being equal to 3000 octal. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------| | | ISK 30000B34 | 1 1 2 1 1 2 1 3 1 1 1 1 1 1 1 1 1 1 | | 1 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 32 | 5 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### The INDEX JUMP Instruction The INDEX JUMP instruction is an instruction that compares the contents of an index register, specified by the index designator $\underline{b}$ , with zero. If the content of the index register is zero, program control continues to the next instruction. If the content of the index register is not zero, program control will jump to address $\underline{M}$ where $\underline{M}$ = $\underline{M}$ + ( $\underline{V}^V$ ) and the index register will be decremented by one. If the bank term $\underline{a}$ (within parentheses) is missing, the current operand bank setting remains. If the bank term $\underline{a}$ is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect (or, cannot jump banks with) this instruction. However, it could affect future instructions that reference memory for operands. Examine the contents of Index Register 1 for being equal to zero. If zero, continue executing. If non-zero, jump to address LOOP. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |---------------|---------------------------------------------------------------------------------------------------------|-------------| | 1 1 1 1 1 1 1 | IJP LOPP 1 | 1 | | | | <del></del> | | 1 2 3 4 5 6 7 | 8 9 10 [11 [12] 13 [14] 15 [16] 17 [18] 19 [20] 21 [22] 23 [24] 25 1 25 [27] 28 [29] 30 [31 [32] 33 [34 | <br> -<br> | #### PROBLEM: Examine the contents of Index Register 2 for being equal to zero. If zero, continue executing. If non-zero, jump to address LOOP modified by Index Register 3. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------|------------------------------------|--------------------------------------------------------| | | IJP L \$ \$ P 2 2 3 | 1 | | 1 2 3 4 1 5 1 6 1 7 1 8 | <br> | \$\\\ 35\\\ 36\\\\ 37\\\\ 38\\\\\\\\\\\\\\\\\\\\\\\\\\ | ## PROBLEM: Examine the contents of Index Register 4 for being equal to zero. If zero, continue executing. If non-zero, jump to the address specified in Index Register 5. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------|----------| | | I.J.P. 12141215 | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 | | #### PROBLEM: Examine the contents of Index Register 6 for being equal to zero. If zero, continue executing. If non-zero, jump to an address five memory locations backward. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------| | | I,JP *,-5,,6 | | | 1 2 3 4 5 6 7 8 | 9 10111 112 113 114 115 116 117 110 119 120 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | 138 39 40 41 42 43 44 45 46 47 48 49 50 | #### NEW CONCEPTS OF GROUP 4 Introduced here is a concept of "looping". The computer has index registers that are used to form address modification for relative addressing. They can also be used to determine the number of times a routine is performed. The ISK instruction checks a counter (contents of an index register) for being equal to a pre-set value. If the two are not equal, the counter is advanced by 1 and a half exit is taken, allowing the programmer to repeat the loop. The programmer can use the same index register as an address modifier within the loop so that he may process data sequentially. If the two are equal, a full exit is taken. This skips the lower instruction and terminates the loop. The IJP instruction checks a counter (contents of an index register) for being equal to zero. If the counter is not zero, it is decremented by 1 and a jump takes place to reenter the loop. If the counter is zero, the next instruction is executed and the loop is terminated. Also introduced at this time is the \* (asterisk) used in the address field in place of an address. It means the present value of the location counter. Hardware-wise it would mean the contents of the P register when the instruction is executed. \* +5 means 5 memory addresses forward (not 5 instructions). \* -10 means 10 (decimal) memory addresses backward. ## Problem 4: A table of 100 words exists in memory, but upside down. Write a subprogram that will re-arrange the words so that the table is right side up. The starting address of the table is TAB. #### Flowchart: Problem 4 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------| | 1 1 2 3 4 5 4 7 4 | | 22 29 24 25 24 27 76 26 30 31 32 35 24 28 34 27 36 29 40 | <br> | | | FDENT 5W | IIT,C.H. | <u> </u> | | | ENTRY Su | IIT.CH. | <u> </u> | | SWITCH. | 855 I | <u> </u> | | | | ENI O, | <u> </u> | COUNTER FOR FIRST WORD | | | ENI 49 | 12 11 11 11 11 11 11 | CAUNTER FOR LAST WORD | | NEXT | LOA TA | 8,1 | <u> </u> | | | LOQ | 18+50,2 | | | 1 1 1 1 1 1 | LDQ TA | 18+50, 2 | | | | STQ TA | $g_{\beta_1}$ , $f_1$ , $f_2$ , $f_3$ , $f_4$ , $f_4$ , $f_4$ , $f_5$ , $f_4$ , $f_5$ , $f_6$ , $f_7$ , $f_8$ | | | | IJP *+ | 11,2,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | | UJP Su | VÍTCH | (B2) = 0, FINISH | | | INI | 1 | <u> </u> | | 111 | UJP WE | EXT | | | | END | المن المراجة التقديدة المنظم المن المنظم المن المنظم المناطق المناطق المناطق المناطق المناطق المناطق المناطق ا | | Somewhere within this subprogram would also be included the symbol TAB in the location field with a declaration of the prestored data or the area reserved. #### Student Problem 4A: There exists in memory 30 words of data starting at address SIGMA. Write a subprogram that will move the first word to the bottom of the list and move the other words up one address. Flowchart: Problem 4A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------------|----------------------------------------------------------------|------------------------------------------------------------------|----------------------------------------| | 1,2,2,1,2,1,1,1,1,1,1 | 10 13 12 13 14 15 14 15 14 15 14 15 15 | ; 24 ; 27 ; 78 ; 28 ; 30 ; 41 ; 32 ; 15 ; 34 ; 37 ; 38 ; 39 ; 16 | ###################################### | | | | <u></u> | | | | <del> </del> | 14.4.4.4.4.1.1.1.1.1.1.1.1.1.1.1.1.1.1. | | | | 1 | | | | | 1 | | | | | ! | | | | | 1 | | | | | | | | | | | | | | | 1 | | | | | | | | | | 1 | | | | | | i | | | | <del> </del> | 1 | | # GROUP 5 FIXED POINT ARITHMETIC #### GROUP 5 ## FIXED POINT ARITHMETIC | 1. | Add | ADD | |----|---------------------|-----| | 2. | Subtract | SUB | | 3. | Multiply Integer | MUI | | 4. | Divide Integer | DVI | | | Multiply Fractional | MUF | | 6. | Divide Fractional | DVF | This group of instructions performs the fixed point arithmetic operations on the $\boldsymbol{A}$ and $\boldsymbol{Q}$ registers. The first four instructions use purely integer arithmetic where the point is assumed to be to the right of the register or register set. The last two use purely fractional arithmetic where the point is assumed to be just to the right of the sign bit. #### The ADD Instruction The ADD instruction is an instruction that adds a 48-bit operand (from an 18-bit storage) to the contents of A. One memory reference is made. The operation leaves the contents of the storage address unchanged. The initial contents of the A register are replaced by the sum of the two operands. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^V)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is added to the contents of A. If MG is specified by the programmer, the magnitude (absolute value) of the operand is added to the contents of A. Add the contents of address SMALLEST to A. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------| | | A.D.D. S.M.A.L.L.E.S.T. | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 13 | 5 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Add the contents of address BIGGEST modified by Index Register 1 to $\ensuremath{\mathrm{A.}}$ #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | $A_{i}D_{i}D_{i}$ | | | 1 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 13 | 7 38 39 40 41 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Add the absolute value of the contents of address FIND to A. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------|--------------------------------------| | | ADD, MG FIND | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 3 | 513613713813914014143143144143143144 | ## PROBLEM: Add the contents of address NOFIND modified by Index Registers 3 and 4 to $\ensuremath{\mathrm{A}}$ . | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------| | | $A_{i}D_{i}D_{i}$ $N_{i}\phi_{i}F_{i}I_{i}N_{i}D_{i}$ , $B_{i}B_{i}B_{i}B_{i}B_{i}B_{i}B_{i}B_{i}$ | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 1 | 39 39 40 41 42 43 44 45 45 45 45 45 | #### The SUBTRACT Instruction The SUBTRACT instruction is an instruction that subtracts a 48-bit operand (from an 18-bit storage address) from the contents of A. One memory reference is made. The operation leaves the contents of the storage address unchanged. The initial contents of the A register are replaced by the difference of the two operands. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = m + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is subtracted from the contents of A. If MG is specified by the programmer, the magnitude (absolute value) of the operand is subtracted from the contents of A. Subtract the contents of address MIN from A. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------| | | $S_{i}U_{i}B_{i}$ $M_{i}I_{i}N_{i}$ | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 3 | <br> | #### PROBLEM: Subtract the contents of address MIN modified by Index Register 3 from $\boldsymbol{A}_{\:\raisebox{1pt}{\text{\circle*{1.5}}}}$ ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | S.U.B. MIN J.N. | | | 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10111 [12]13 14 [15]16 17 [16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 3 | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Subtract the absolute value of the contents of address TOPS from A. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------| | | SUB.MG TOPS | 1 | | 1 2 3 4 5 6 7 8 | 9 10 [11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | <br> <br> 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Subtract the contents of address SPOT modified by Index Registers 3 and 4. $\,$ | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------| | | $S_{i}v_{i}B_{i}$ $S_{i}P_{i}\phi_{i}T_{i}$ $S_{i}y_{i}4$ | | | 1 2 3 4 5 6 7 8 | 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | ### The MULTIPLY INTEGER Instruction The MULTIPLE INTEGER instruction is an instruction that multiplies a 48-bit operand (from an 18-bit storage address) by the contents of A in fixed-point format. One memory reference is made. The operation leaves the contents of the storage address unchanged. The initial contents of the QA registers are replaced by the 96-bit product of the two operands. The point is assumed to be to the right of A with sign extended through Q. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is multiplied by the contents of A. If MG is specified by the programmer, the magnitude (absolute value) of the operand is multiplied by the contents of A. Multiply A by the contents of address SUR. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------| | | MUI | 1 | | 1 2 3 4 5 6 7 8 | 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 36/37/38/39/40/4/42/43/44/45/45/47/40/40/40 | #### PROBLEM: Multiply A by the contents of address PETE modified by Index Register 1. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------------------------------------|------------------------------------------------| | | $M_iU_iI_i$ $P_iE_iT_iE_{i,2,1}$ | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 1361371381391401411421431441451461471481491801 | #### PROBLEM: Multiply A by the absolute value of the contents of address JACK modified by Index Register 2. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------| | | MUI,MG JACK 2 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | 1301391401411421431441441451461431461431461 | #### PROBLEM: Multiply A by the contents of HOMER from the bank where $\ensuremath{\mathsf{HOMER}}$ resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------| | | $M_iU_iI_i$ $(.\$_i)_iH_i\phi_iM_iE_iR_i$ | 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 | 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### The DIVIDE INTEGER Instruction The DIVIDE INTEGER instruction is an instruction that divides the contents of QA by a 48-bit operand from an 18-bit storage address in fixed-point format. One memory reference is made. The operation leaves the contents of the storage address unchanged. The initial contents of the A register are replaced by the quotient of the two operands. The initial contents of the Q register are replaced by the remainder of the operation. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand from memory is used as the divisor. If MG is specified by the programmer, the magnitude (absolute value) of the operand from memory is used as the divisor. Divide QA by the contents of address DIVIS. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------| | | $D_iV_iI_i$ $D_iI_iV_iI_iS_i$ | | | 1 2 3 4 5 6 7 8 | <br> 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 136 37 38 39 40 41 42 43 44 45 45 45 47 48 49 50 | ## PROBLEM: Divide QA by the contents of TRAVIS modified by Index Register 3. #### SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|--------------------------------------------------------------------------------------------------------------|---------------------------------------------| | | $D_{i}V_{i}I_{i}$ | ! | | 1 2 3 4 5 6 7 8 | 9 (0] (1 [12] (3 [14] (5 [16] (7 [18] [19] 20 [21 [22] 23 [24] 25 [26] 27 [28] 29 [30 [31 [32] 33 [34] 35 [3 | 6 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Divide QA by the contents of the address specified in Index Register 4. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | | D <sub>1</sub> V <sub>1</sub> J <sub>1</sub> 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | 7138139140141142143144145146147;48149150 | ## PROBLEM: Divide QA by the contents of address $\ensuremath{\mathtt{GUBER}}$ from the bank that DVI is in. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|--------------------------------------------------------------------------------------------------------|--------------------------------------------------| | | $D_iV_iI_i$ $(x_i)_iG_iU_iB_iE_iR_i$ | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 115 114 115 116 117 118 119 120 21 122 123 124 125 126 127 128 129 130 131 132 133 134 13 | 151361371381391401411421431441451461471401491501 | #### The MULTIPLY FRACTIONAL Instruction The MULTIPLY FRACTIONAL instruction is an instruction that multiplies a 48-bit operand (from an 18-bit storage address) by the contents of A in fractional format. One memory reference is made. The operation leaves the contents of the storage address unchanged. The initial contents of the AQ registers are replaced by the 96-bit product of the two operands. The point is assumed to be to the right of the sign bit in A with the fraction extended through Q. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = m + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is multiplied by the contents of A. If MG is specified by the programmer, the magnitude (absolute value) of the operand is multiplied by the contents of A. Multiply A by the contents of address PYLE. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | | MUF | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 3 | 7.730.730.400.400.400.400.400.400.400.400.400.4 | #### PROBLEM: Multiply A by the contents of address PIKE modified by Index Register 2. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------| | | $M_iU_iF_i$ $P_iI_iK_iE_i$ $D_i^2$ | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 137 39 39 40 41 42 43 44 45 45 47 48 49 40 | #### PROBLEM: Multiply A by the contents of the address specified in Index Register 4. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|------------------------------------------------------------------------------------------------|-------------------------------------| | | M <sub>I</sub> U <sub>I</sub> F <sub>1</sub> 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 1 | | 1 12 3 4 5 6 7 8 | 9 10 111 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 29 30 31 32 33 34 35 36 37 38 3 | 9]40]41]42]43]44]45]46]47]48]49]50] | #### PROBLEM: Multiply A by the absolute value of the contents of address MOOSE. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------------------------------------------------------|-------------------------------------------------------| | <u> </u> | M.U.F., M.G. M. Ø. Ø. S.E. | <br> | | 1 2 3 4 5 6 7 8 | 9 10[11 [12 [15]14]15 [16]17[16]19 [20]21[22[23]24[25]26[27]28[29]30[31]32[53]34[3 | 51361371381391401411421431441431461471461471461401601 | #### The DIVIDE FRACTIONAL Instruction The DIVIDE FRACTIONAL instruction is an instruction that divides the contents of AQ by a 48-bit operand from an 18-bit storage address in fractional format. One memory reference is made. The operation leaves the contents of the storage address unchanged. The initial contents of the A register are replaced by the quotient of the two operands. The initial contents of the Q register are replaced by the residue of the operation. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand from memory is used as the divisor. If MG is specified by the programmer, the magnitude (absolute value) of the operand from memory is used as the divisor. Divide AQ by the contents of address DIV. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------|------------------------------------|---------------------------------------------------| | | $D_1V_1F_1$ $D_1I_1V_1$ | | | 1 2 3 3 4 5 6 7 1 | <br> | 4 35 36 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Divide AQ by the contents of JAKE modified by Index Register 5. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------| | | DVF JAKE,5 | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Divide AQ by the contents of the address specified in Index Register 4. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | | DIVIF | | | 1 12 3 4 5 6 7 6 | 9 10 11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 20 31 32 35 36 35 36 35 36 35 36 35 36 35 36 35 36 36 | <br> | ## PROBLEM: Divide AQ by the contents of address PORKY modified by Index Registers 2 and 3. $\,$ | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------|----------------------------------------------------------| | | DIVIF PØRKY 23 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 20 21 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 | 137 (38 (39) 40) 41 (42 (43) 44 (45) 46 (47) 48 (49) 50) | | • | | | |---|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### NEW CONCEPTS OF GROUP 5 The instructions in this group operate on two types of operands - integer and fractional. The ADD, SUB, MUI, and DVI instructions operate on integers only. The MUF and DVF instructions operate on fractions only. Each set must be kept separate and distinct. Let's first discuss integers. #### INTEGERS Integers are the counting numbers 1, 2, 3 ... in the positive direction and -1, -2, -3... in the negative direction with 0 as the origin. In algebra we represent these numbers on a number scale as such: 5 4 3 2 1 0 \_ 1 - 2 - 3 - 4 **-** 5 The range in both directions is unlimited. From algebra we also know that +2 is greater than -5. On the computer these numbers are represented in binary. But binary is very difficult to read and very cumbersom to work with. Since binary expands easily to octal, we will use octal representation to illustrate the format and the range of the numbers. The format for integer numbers has the sign of the number in the most significant bit position and the rest of the positions giving the actual number. For positive numbers the correspondence between the algebraic notation and computer notation is as follows: # Algebraic Notation ## Computer Notation | | | • | |---|---|------------------------| | | | • | | | | • | | 4 | : | 0 -> 04 | | 3 | | 0> 03 | | 2 | 2 | 0->02 | | 1 | | $0 \longrightarrow 01$ | | 0 | | 0> 00 | | | | | The range for positive algebraic numbers is to infinity. The range for the positive numbers on the computer is as much as the 48-bit word can handle. In octal the maximum number is $37 \longrightarrow 7$ . If we add 1 to this number, the number turns negative $(40 \longrightarrow 0)$ which is an incorrect answer. When an operation occurs in which the result exceeds this maximum count, an "overflow" condition results which is interruptible. This is termed Arithmetic Overflow Fault. The computer also allows negative numbers. Here is a comparison between negative algebraic numbers and the computer representation. | Algebraic Notation | Computer Notation | |--------------------|----------------------| | 0 | 0> 0 | | -1 | 7>76 | | <del>-</del> 2 | 7>75 | | - 3 | 7->74 | | -4 | 7 <del>&gt;</del> 73 | The smallest number represented on the computer is $40 \longrightarrow 0$ . The number $7 \longrightarrow 7$ on the computer is termed "negative zero". This number will not result from an add of subtract operation, except for a special case, since 1's complement arithmetic is used. What we mean by this is that if 1 is added to $7 \longrightarrow 76$ the result will be $0 \longrightarrow 0$ just as should be in algebra. An important concept about relating the algebraic and computer numbers system is the talk about "complementing. In algebra the complement of a number is the number with its sign reversed. A + 5 complemented is -5. A -30 complemented is +30. In the computer it means, "for every 1 bit change to 0, for every 0 bit change to a 1", The complement of $0 \longrightarrow 04$ is $7 \longrightarrow 73$ . The complement of $7 \longrightarrow 763$ is $0 \longrightarrow 014$ . Try it yourself on the following table and make sure you understand the relationship between algebraic numbers and their computer representation. | Algebraic Notation | Computer Notation | |--------------------|-------------------| | | 37>77 | | • | | | | | | 3 | 0> 03 | | 2 | 0>02 | | 1 | 0>01 | | 0 | 0> 00 | | - 1 | 7> 76 | | -2 | 7> 75 | | -3 | 7> 74 | | | | | | | | | 40>00 | The instructions ADD, SUB, MUI, DVI operate on these integers and will yield the corresponding algebraic results. Now let's look into fractions and their computer representation. #### **FRACTIONS** If you understood the integer representation of numbers, then fractional representation should not be difficult. Fractions are numbers from 0 up to but not including 1, both positive and negative directions. In algebra we can represent these numbers on a number scale as such: .3 . 2 .1 0 -.1 -.2 -.3 The machine format again has the sign of the fraction in the most significant bit position and the rest of the positions giving the actual fraction. The point is considered to be between bit positions 47 and 46. For positive fractions the correspondence between the algebraic notation and computer notation is as follows: | Algebraic Notation | Computer Notation | |--------------------|-------------------| | | • | | • | • | | .3 octal | 140>0 | | .2 octal | 100>0 | | .1 octal | 040>0 | | 0 | 000>0 | The computer notation may seem strange at first. But the representation is correct. Consider .1 octal: - 1. .l octal = .001 binary - 2. .001 binary = 0.001 binary - 3. 0.001 binary = $040 \longrightarrow 0$ octal (regroup) The computer also allows negative fractions. Here is a table representing a comparison between the two systems. | Algebraic Notation | Computer Notation | |--------------------|-------------------| | .3 octal | 140> 0 | | .2 octal | 100> 0 | | .1 octal | 040 -> 0 | | 0 | 000> 0 | | 1 octal | 737> 7 | | 2 octa1 | 677 -> 7 | | 3 octal | 637 -> 7 | | I | ı | The negative computer fractions may seem strange and you may wonder how they were arrived at. As a helpful aid in understanding the negative conversion, keep in mind the principle used to convert negative integers, and then note how the above negative fractions are complements of their positive counterparts. # FAULTS What computer faults can result from the execution of any of the six instructions within this group? | | Instruction | Possible Fault | |----|-------------|---------------------------------------------------------| | 1. | ADD | Arithmetic Overflow Fault - adding two positive oper- | | | | ands where the result ex- | | | | ceeds the maximum positive | | | | limit, <u>or</u> adding two negative | | | | operands where the result | | | | exceeds the maximum nega- | | | | tive limit. Adding a positive | | | | to a negative operand will | | | | never yield overflow since | | | | the answer will move closer | | | | to zero. | | 2. | SUB | Arithmetic Overflow Fault -subtracting a negative oper- | | | | and from a positive operand | and the result exceeds the maximum positive limit, or subtracting a positive operand from a negative operand and the result exceeds the maximum negative limit. Subtracting operands with like signs will never yield overflow. | 3. | MUI | No possible fault since the product of any two operands will fit into a 96 bit register (QA). | | | |----|-----|-----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 4. | DVI | Divide Fault - | dividing by zero <u>or</u> a division where the dividend so exceeds the divisor that the answer is not capable of fitting into a 48 bit register(A). | | | 5. | MUF | No possible fault since the product of any two operands will fit into a 96 bit register (AQ). | | | | 6. | DVF | Divide Fault - | | | All faults mentioned are computer interruptible. # Problem 5: Evaluate Z as close as possible if Z = $\frac{3X-2Y}{4Y-X}$ where X and Y are integers whose absolute values are less than 500. # Flowchart: Problem 5 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIE | RS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------| | 112121412141214 | 9 10 ( 11 ( 12 ( 13 ( 14 ( 15 ( 16 ( 17 ( 18 ( | • [80][2] [27][37][34][25][26][37][78][26][36][31][22][35][34][35][34][37][38][39][4 | 0 41 42 143 44 145 144 147 144 147 147 147 147 147 147 147 | | | IDENT | EVAL | | | | ENTRY | EVAL | | | DIVIS | BSS. | 12. | | | CON1 | DEC | 4 | | | CPN2 | DEC | 3 | | | EVAL | BSS | 2 | | | LLITTLE | LDA | Ŋ | | | | MUI | CON1 | | | <u> </u> | 54B | X | <del>4</del> 4/-× | | | STA | DIVIS | | | | LDA | X | | | 11111 | MUI | K. du/2 | | | | BUB | <u>M </u> | | | | SUB | <u>i</u> | 3x-21 | | _1_1_1_1_1_1_1 | AJP, PL | EXTZER | EXTEMO | | | ENQ | <u> </u> | SIGN | | 111111 | 547 | | THROUGH | | EXTZER | ENQ | <u> </u> | Q | | $\rho_{IV}$ | | DIVIS | | | | | Z | | | | | EVAL | | | | END | | | Somewhere within this subprogram would also be included the symbols X and Y in the location field with a declaration of the prestored data or area reserved. # Student Problem 5A: Evaluate W = $\frac{3R-S+5T}{S-T}$ +1 if R, S, and T are integers whose absolute value is less than 100. Flowchart: Problem 5A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 12 12 14 18 14 17 18 | 9 100 1 22 1 12 1 12 1 14 1 15 1 14 1 15 1 15 | 2 271 24 25 24 77 28 29 30 31 33 33 34 35 36 37 38 39 46 | 0.0101410141014101919191919191919191919191 | | | | | | | | <del> </del> | | | | | <del> </del> | | | | | <del> </del> | <u> </u> | | | <u> </u> | <del> </del> | | <u> </u> | | | <del> </del> | <u>_ </u> | <u> </u> | | <del> - - - - - - - - - - - - - - - - - - - - - - - </del> | <del> </del> | | | | | | | <u> </u> | | | | <u></u> | | | | | <u> </u> | | | | | | | | | | | | | | | | <u> </u> | | | | <u> </u> | <u> </u> | | | | <u> </u> | | | | <u> </u> | <u>.</u> | Landado de comunidade en la calculación de la comunidade | | 1111111 | <del> </del> | | | | | | | | | | | | <u> </u> | | | | | 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - | | | <del> </del> | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | # GROUP 6 REPLACE OPERATIONS # GROUP 6 # REPLACE OPERATIONS | 1. | Replace Add | RAD | |------------|----------------------|-----| | $^2 \cdot$ | Replace Subtract | RSB | | 3. | Replace Add One | RAO | | 4. | Replace Subtract One | RSO | This is a group of instructions that adds or subtracts a quantity from a storage address. The same result left at the storage address also remains in A. Two storage cycles are required for each instruction. The first two instructions add or subtract the contents of A from the contents of the storage address. The last two instructions increment or decrement the contents of the storage address by one. This result remains in A. The initial contents of A are not used and are destroyed by these instructions. ### The REPLACE ADD Instruction The REPLACE ADD instruction is an instruction that adds a 48-bit operand from an 18-bit storage address to the contents of A and returns the result to both the A register and the storage address in memory. Two memory references are made. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is added to the contents of A and the result returned to both the A register and the storage address in memory. If MG is specified by the programmer, the magnitude (absolute value) of the operand is added to the contents of A and the result returned to both the A register and the storage address in memory. Add A to the contents of address POPS. ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------|-------------------------------------| | | RAD POPS | | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12]13]14 [15]16 [17]18 [19]20[21]22[23]24[25[26]27[28]29]30[31]32[33]34[35]36[37]38 | 39140141142143144145146147140140140 | ### PROBLEM: Do a replace add to the contents of address BLO modified by Index Registers 1 and 2. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------| | | RAD | | | 1 12 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | ### PROBLEM: Do a replace add to A with the absolute value of the contents of address PLUG. ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------| | | $R_{i}A_{i}D_{i}M_{i}G_{i}$ $P_{i}L_{i}U_{i}G_{i}$ | | | 1 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | 35 36 37 38 39 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: Do a replace add to A using the contents of the address specified in Index Register 5. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------|-------------------------------------| | | $R_{i}A_{i}D_{i}$ | 1 | | 1 2 3 4 5 6 7 8 | <br> 9 | 91401411421431441451461471481491501 | # The REPLACE SUBTRACT Instruction The REPLACE SUBTRACT instruction is an instruction that subtracts the contents of A from a 48-bit operand (from an 18-bit storage address) and returns the result to both the A register and the storage address in memory. Two memory references are made. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the contents of A are subtracted from the complement of the operand from memory and the result returned to both the A register and storage address in memory. If MG is specified by the programmer, the contents of A are subtracted from the magnitude (absolute value) of the operand from memory and the result returned to the A register and storage address in memory. Subtract A from the contents of address MACK with the result transmitted to address MACK. ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------| | | $R_{i}S_{i}B_{i}$ | | | 1 12 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | 38139140141142143144145145145147140140140 | # PROBLEM: Do a replace subtract on the contents of address TABLE modified by Index Register 1. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------|----------------------------------------------------------------------------------------------------------------------------------------|----------| | | RISB TABLE, 1 | | | 1 2 3 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | | ### PROBLEM: Do a replace subtract on the contents of address TEST modified by Index Registers 1 and 2. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | RSB | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 35 34 35 | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: Do a replace subtract on the contents of the address specified in Index Register $6. \,$ | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------| | | RSB. | | | 1 2 3 4 5 6 7 8 | 9 10 111 (12 113 114 115 116 117 116 119 120 (21 122 23 24 25 26 27 28 29 30 31 32 33 34 3 | 35[36]37[38]39[40]4: 42]43[44:45]46[47]48[49]50] | # The REPLACE ADD ONE Instruction The REPLACE ADD ONE instruction is an instruction that increments a 48-bit operand from an 18-bit storage address by 1 and returns the result to both the A register and the storage address in memory. The initial contents of A are not used and are destroyed during the operation. Two memory references are made. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = m + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand from memory is incremented by 1 and the result returned to both the A register and the storage address in memory. If MG is specified by the programmer, the magnitude (absolute value) of the operand is incremented by 1 and the result returned to both the A register and the storage address in memory. Increase the contents of address SAM by one. ### SOLUTION: | LOCN | | OPERATION, MODIFIERS ADDRESS FIELD COMMENTS | | |-------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | | | $RA\phi_{1}$ | 1 1 | | 1 2 3 4 5 6 7 8 | , | 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 4 | 9 50 | # PROBLEM: Add one to the contents of REPEAT indirectly. ### SOLUTION: | LOCN | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | | |-------------------------------|---|-------------------------------------------------|--------------------------|----------|--| | 1 1 1 1 1 1 | | RAP | REPEATON | | | | 1 2 3 4 5 6 7 8 | 9 | 10 11 12 13 14 15 16 17 18 19 | 120 21 22 23 24 25 26 27 | | | # PROBLEM: Add one to the contents of the address specified in Index Register 6. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------|----------------------------------------------------------------------------------------------------------------------|--------------------------------------| | | $RA\emptyset$ | 1 | | 1 12 13 14 15 16 17 18 | 9 10 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 | 13914014 142141144145145147149149150 | ### PROBLEM: Add one to the contents of address PUNCH in the bank that the RAO is in. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------| | | RAD PUNCH | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | 1:39:40:4::42:43:44:45:46:47:48:49:50 | ### The REPLACE SUBTRACT ONE Instruction The REPLACE SUBTRACT ONE instruction is an instruction that decrements a 48-bit operand from an 18-bit storage address by 1 and returns the result to both the A register and the storage address in memory. The initial contents of A are not used and are destroyed during the operation. Two memory references are made. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand from memory is decremented by 1 and the result returned to both the A register and the storage address in memory. If MG is specified by the programmer, the magnitude (absolute value) of the operand is decremented by 1 and the result returned to both the A register and the storage address in memory. Decrease the contents of address NUMBER by one. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|--------------------------------------------------------------------------------------------------------------|------------------------------------| | | $R \leq \emptyset$ $N \cup M \cap B \in R$ | 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 [12]13 14 115 [16]17 [18 119 [20]21 [22]23]24 [25] 26[27]28 [29]30 [31 [32]33 [34] 35 [36]37 [38] 3 | 9 40 4 42 43 44 45 46 47 40 40 40 | # PROBLEM: Subtract one from the contents of SLIP modified by Index Register 2. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------| | | RSØ SLIP, 2 | 1 | | 1 [2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 3 | 35 36 37 38 39 40 4 42 43 44 45 45 45 47 48 49 60 | # PROBLEM: Subtract one from the contents of the address specified in Index Register 3. # SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------| | | $RS\emptyset$ | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 3 | 9 40 41 42 43 44 45 46 47 48 49 50; | # PROBLEM: Subtract one from the contents of the address three memory locations forward of this instruction. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------| | | $R_1S_1\phi_1$ | | | 1 2 3 4 5 6 7 8 | 9 10 11: 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 132 33 34 | 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | # NEW CONCEPTS OF GROUP 6 The instructions in this group provide the programmer with an easy way to add or subtract data from a memory address. Each instruction performs the arithmetic in fixed point integer format. Arithmetic Overflow can occur if the limits $\pm (2^{47}-1)$ are exceeded. # Problem 6: Given: $Y = X^5 - 4X^3 + 135$ There exists one integer for X between 0 and -10 such that, when it is substituted, will cause Y to be equal to zero. Find that integer and store it at address X. Problem 6 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIE | ERS ADDRESS FIELD | COMMENTS | |------------------------|------------------------------------------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------| | . 12 12 14 12 14 17 17 | • 16 ( 11 ) 17 ( 13 ) 14 ( 15 · 16 ) 17 ( 18 ) | [28 28 27 27 27 28 28 27 28 27 28 28 | 9 0 1-2 0 6 6 6 6 6 8 12 3 3 4 12 8 12 9 13 14 14 14 14 14 14 14 | | | IDENT | SOLVE | | | | ENTRY | SPLVE | | | CAN1 | DEC | 4 | | | CPN2 | DEC | 135 | | | X | DEC | -10 | | | SAVE 1 | BSS | 12:11:11:11:11:11:11:11:11:11:11:11:11:1 | X CUBED | | SAVEZ | B.S.S. | <u> </u> | | | SOLVE | BSS | <u>. </u> | | | | LDA | _ <u> X</u> | | | TRYAGN | MUI | · X | X SQUARED | | | MUI | · X | X CUBED | | | 51A | SAVE1 | | | | MuI | <u> </u> | X 4TH | | | MuI | X | X.STH | | | 5TA | SAVEZ | <u> </u> | | | LPA. | SAVEZ<br>CONI | 4X CUBED | | | MUI | SAVEZ | , -TX C4BED | | | ADD | CON2 | X**5-4X**3+135 | | | 400 | SOLVE | EXIT | | | AJP, ZR | | | | | RAD | TRYAGN | | | | END | , <u> </u> | | | | I MU | | | | | ++++++++ | <u> </u> | <u> </u> | # Student Problem 6A: Given: $Y = 3X^3 - 4X^2 - 34385$ There exists one integer for X between 0 and 30 such that, when it is substituted, will cause Y to be equal to zero. Find that integer and store it at address X. Flowchart: Problem 6A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 1 2 1 2 1 4 1 4 1 4 1 7 1 4 | • ************************************* | 20 21 22 25 24 25 24 27 26 20 30 31 32 33 24 35 36 37 30 39 40 | <br> | | <b> </b> | | <u> </u> | | | | | | <br> | | | ++ | | <u> </u> | | | <del></del> | | | | <u> </u> | | | | | | | <u> </u> | | | | <u> </u> | | 1 | | | | <u></u> | <u> </u> | | | + | | <u> </u> | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ,<br> | | | | | <u>.</u><br>1. <u> </u> | | | | | <br> | | | | | | | | | | | | | | | | | | | enderseker skurskrauter sammten å <u>så så sakstaller at enderseker sk</u> asset samt. | | | | | للبرجي بقريف فروا يك يكت افتك بالكالك المتلك كالبالك المتلاطرة المت | and the second th | | <u> </u> | <del> </del> | | | # GROUP 7 JUMPS AND STOPS ### GROUP 7 # JUMPS AND STOPS | 1. | Unconditional Stop/Jumps | SLX | |----|-------------------------------------|-----| | 2. | Selective Jumps | SJX | | 3. | A Jump | AJP | | 4. | Q Jump | QJP | | 5. | Selective Stops (with Normal Jumps) | SSX | This group of instructions allows the programmer to stop the computer (if not illegal), and to transfer program control to another area of the program. It is important to note that the jumps are not bank jump instructions in any way. The purpose for the bank term is to set or reset the Operand Bank setting only. The jump is still within the same bank in which current program control is operating. Some of the jumps and stops are conditional. They are conditioned by the contents of A, the contents of Q, the Jump switches, and the Stop switches. # The UNCONDITIONAL STOP/JUMP Instruction The SELECTIVE JUMP instruction is an instruction that transfers program control unconditionally to another point within the program. The jump address to which control is transferred is $\underline{M}$ where $M = m + (V^{V})$ . The jump is made within the same bank that the program is operating, i.e., this is not a bank jump instruction. The bank term $\underline{a}$ determines the value of the operand bank setting. If it is not used, the current operand bank setting remains. If it is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. The SELECTIVE STOP instruction is an instruction that unconditionally stops the computer. When the computer is restarted, program control unconditionally transfers to another point within the program. The SELECTIVE STOP instruction then follows the same form as the SELECTIVE JUMP (paragraphs 2 and 3 above). Perform an Unconditional Jump to address LOOP. ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------| | | $S_iL_jJ_i$ | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | 139140141142143144145145147140140140 | ### PROBLEM: Perform an Unconditional Jump to BEGIN. The routine at BEGIN is to pick up operands from Bank 3. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------|-------------------------------------| | | $S_{1}L_{1}J_{1}$ $(3)B_{1}E_{1}B_{1}$ | 1 | | 1 2 3 4 5 6 7 8 | 9 10[11]12]13[14]15[16]17[18]19[20[21]22[23]24]25[26]27[28]29[30[31]32[33]34]35[36]37[38]3 | 91401411421431441451461471481491501 | # PROBLEM: Stop the computer. When restarted, a jump to address START is to be made. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | | $S_{i}L_{i}S_{i}$ | | | 1 2 3 4 5 6 7 8 | <br> 9 10 11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 32 | 134[35]36[37]38[39]40[4:[42]43[44]45[46[47]48[49]50: | # PROBLEM: Stop the computer. When restarted, a jump 3 memory locations forward is to be made. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------|---------------------------------------------------------------------| | | S <sub>1</sub> L <sub>1</sub> S <sub>1</sub> | | | 1 2 3 4 5 6 7 8 | <br> 9 | 37 [38 ] 39 ] 40 41 142 43 44 45 46 47 48 49 50 | # The SELECTIVE JUMP Instructions The SELECTIVE JUMP instructions are conditional jump instructions that test the three jump switches on the console to see if they are ON or OFF. There is one jump instruction for each switch. If the jump switch is ON, program control transfers to address $\underline{M}$ where $\underline{M}$ = $\underline{m}$ + ( $\underline{V}^{V}$ ). This address is a 15-bit address within the same bank that the program is operating, i.e., this is <u>not</u> a bank jump instruction. If the jump switch is OFF, program control continues executing in its normal sequence with no jump being made. The bank term $\underline{a}$ determines the value of the operand bank setting. If it is not used, the current operand bank setting remains. If it is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. Check Jump Switch 1. If ON, jump to address CARDTOTA. If OFF, continue program. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------------------|----------| | | SJ1 CARDTOTA | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 13 14 15 16 17 118 119 20 21 22 23 24 25 26 27 2 | <br> | # PROBLEM: Check Jump Switch 2. If ON, jump to address OK modified by Index Register 3. If OFF, continue program. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|-------------------------------------------------------------------------------------------------------------------------|----------------------------------| | | $SJ_2$ | 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 20 21 122 23 24 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 14 | 0[4: [42]43]44]45]46]47]48 49 50 | #### PROBLEM: Check Jump Switch 3. If ON, jump to the address specified in Index Register 4. If OFF, continue program. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|----------------------------------------------------------------------| | | SJ3 | | | 1 2 3 4 5 6 7 8 | <br> | 137 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Check Jump Switch 3. If ON, jump to an address two memory locations forward. If OFF, continue program. | LOCN | 0 | PERATION, MODIFIERS ADDRESS FIELD | COMM | ENTS | |-----------------|------|----------------------------------------|-------------------------|-------------------------| | | 5 | 5,5,3,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | | 1 2 3 4 5 6 7 8 | 9 10 | <br> | 18 13 9 14 0 14 14 2 14 | 31441451461471481491501 | #### The A JUMP Instruction The A JUMP instruction is a conditional jump instruction that tests the contents of A for zero, non-zero, positive, or negative. One modifier must be specified. If the condition tested is true, program control transfers to address $\underline{M}$ where $\underline{M}$ = $\underline{m}$ + $(V^V)$ . This address is a 15-bit address within the same bank that the program is operating, i.e., this is <u>not</u> a bank jump instruction. If the condition tested is not true, program control continues executing in its normal sequence with no jump being made. The bank term $\underline{a}$ determines the value of the operand bank setting. If it is not used, the current operand bank setting remains. If it is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. When A is zero, a jump is to be made to address ROOT. When A is non-zero, the program will continue. What instruction will check this? #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------| | | AJP, ZR ROOT | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 3 | <br> 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: If A is positive, jump to address EPSILON modified by Index Register 3. If A is negative, continue program. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | $A_{1}J_{1}P_{1}J_{1}P_{1}L_{1}$ $E_{1}P_{1}S_{1}J_{1}\phi_{1}N_{1}J_{3}J_{1}J_{1}J_{2}J_{3}J_{1}J_{2}J_{3}J_{3}J_{3}J_{3}J_{3}J_{3}J_{3}J_{3$ | | | 1 2 3 4 5 6 7 8 | 9 10[11 12[13] 14 15 16 17 10 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 3 | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: If A is negative, jump to the address specified in Index Register 4. If A is positive, continue program. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|-------------------------------------------------------------------------------------|---------------------------------------------------------| | | A.JP., MI | . 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 [2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 132 33 34 35 13 | 35 13.7 138 139 140 140 140 140 140 140 140 140 140 140 | # PROBLEM: If A is non-zero, jump three locations backward. If A is zero, continue program. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|---------------------------------------------| | | AJP. NZ X-3 | | | 1 2 3 4 5 6 7 8 | 9 | [37]38[39]40[4: 42]43]44[45]46[47]48[49]50 | # The Q JUMP Instruction The Q JUMP instruction is a conditional jump instruction that tests the contents of Q for zero, non-zero, positive, or negative. One modifier must be specified. If the condition tested is true, program control transfers to address $\underline{M}$ where $\underline{M}$ = $\underline{m}$ + $(V^V)$ . This address is a 15-bit address within the same bank that the program is operating, i.e., this is <u>not</u> a bank jump instruction. If the condition tested is not true, program control continues executing in its normal sequence with no jump being made. The bank term $\underline{\underline{a}}$ determines the value of the operand bank setting. If it is not used, the current operand bank setting remains. If it is used, the current operand bank setting will be replaced by the value $\underline{\underline{a}}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. When Q is zero, a jump is to be made to address PARAMET. When Q is non-zero, the program will continue. What instruction will check this? #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | Q.J.P., Z.R. PARAMET | 1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1. | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 129 30 13 132 33 134 135 1 | 35 37 38 39 40 41 42 43 44 45 45 47 40 40 40 | # PROBLEM: If Q is positive, jump to address LAMBDA modified by Index Register 3. If Q is negative, continue program. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------|------------------------------------------------| | | QJP, PL LAMBDA, 3 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 12 113 114 115 116 117 118 119 220 221 222 23 224 25 126 27 128 129 130 131 132 133 134 135 | 1361371381391401411421431441451461471481491501 | # PROBLEM: If Q is negative, jump to the address specified in Index Register 5. If Q is positive, continue program. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | | $QJP_{1}MI_{1}$ | 1 | | 1 2 3 4 5 6 7 8 | 9 :0[11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 3 | 5136;37;38;39;40;47;42;43;44;45;46;47;48;49;50; | #### PROBLEM: If Q is non-zero, jump two locations forward. If Q is zero, continue program. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------| | | QJP, NZ +-2 | 1.4.1.1.1.1.1.1.1.1.1.1.1.1.1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 136 (37 (38 ) 39 ) 40 (4) (42 ) 43 ) 44 45 ) 46 ) 47 48 ) 49 ) 50 . | # The SELECTIVE STOP Instructions The SELECTIVE STOP instructions are conditional stop instructions that test the three stop switches on the console to see if they are ON or OFF. There is one stop instruction for each switch. If the stop switch is ON, the computer will stop. When the computer is restarted, program control will transfer to address $\underline{M}$ where $\underline{M}$ = $\underline{m}$ + ( $\underline{V}^{V}$ ). This address is a 15-bit address within the same bank that the program is operating, i.e., this is <u>not</u> a bank jump instruction. If the stop switch is OFF, the computer will not stop. However, program control still goes to address $\underline{M}$ . The bank term $\underline{a}$ determines the value of the operand bank setting. If it is not used, the current operand bank setting remains. If it is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. Stop the computer if Stop Switch 1 is ON. When restarted, go to address CONT. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | $S_iS_iI_i$ | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 113 114 115 116 117 118 119 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 31 | 7 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Check Stop Switch 2. If ON, stop the computer. If OFF, do not stop. In either case, jump to address JIM modified by Index Register 3. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------| | | $S_1S_2$ $J_1I_1M_1$ $J_3$ | | | 1 2 3 4 5 6 7 8 | 9 00 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Check Stop Switch 3. If ON, stop the computer. If OFF, do not stop. In either case jump to the address specified in Index Register 6. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|-----------------------------------------------|----------| | | S,S,3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, | 1 | | 1 2 3 4 5 6 7 8 | <br> 9 | <br> | # PROBLEM: Check Stop Switch 2. If ON, stop the computer. If OFF, do not stop. In either case jump to one memory location forward of the address specified in Index Register 4. | LOCN | | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |----------------------------|---|------------------------------------|-------------------------------------| | | | 5.5.2 | | | 12 3 4 5 6 7 8 | 9 | <br> | 3914014 142143144145145147148149150 | #### NEW CONCEPTS OF GROUP 7 The conditional jump and stop instructions allow the program to check data and switches and perform various functions accordingly. For the A and Q jumps the whole register is checked for zero when ZR or NZ is specified. When PL or MI is specified, only the uppermost bit is checked. This falls in line with the integer and fractional formats already discussed, and floating point which is coming soon. For the checking of the jump switches and stop switches the number of the switch checked must be on in order for the jump or stop condition to be satisfied. For the conditional jump instructions program control will either jump or continue to the next instruction. For the conditional stop instructions program control will either stop or not stop. In either case it always jumps when it continues. # Problem 7: Write a subprogram that will form: - 1. C = A+B if jump switch #1 is on - 2. C = A-B if jump switch #2 is on - 3. C = A B if jump switch #3 is on Assume only one switch is on and that A and B are given as integers. # Flowchart: Problem 7 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|-------------------------------------------------------------|----------------------------------------------------------------------------------------|---------------| | 112121612161714 | • 10 13 13 14 15 14 17 18 19 20 23 23 | 27 (24 25 24 27 25 26 20 31 32 33 34 35 34 37 38 39 40 | 1<br> | | | IDENT SWI | | | | | ENTRY SWI | TCH | | | <u> </u> | BS.5 | | | | 5 WITCH | BSS. 1 | | | | | SJ1 SUM | | FUMP SW 1 BN? | | | SJ2 DIF | | JUMP SW 2 dN? | | | S.J.3 PRØ | | JUMP SW 3 ON? | | | SLJ SWI | TCH | | | SUM | LOA. A. | ساداده باداده باداده بالمسادية والمساورين | | | | 400 B | | 4+8 | | | STA. | | | | | 54.J., 5w; | [RH | | | DIFF | LOA A | | | | | SUB B | | A-B. | | | STA C | | | | | 545 , SWI | TCH | | | PRAO | LPAA | | | | | MUI B | | 48 | | | STAC | | | | | | TGH, | | | | END | | | Somewhere within this subprogram would also be included the symbols A and B in the location field with a declaration of the prestored data or the area reserved. # Student Problem 7A: Write a subprogram that will form: - 1. Z = X+Y if jump switch 1 is on and jump switch 2 if off. - 2. Z = 2X+3Y if jump switch 2 is on and jump switch 1 is off. - 3. Z = 3X-2Y if both jump switches 1 and 2 are on. Flowchart: # Problem 7A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------| | 112121414141714 | * ************************************ | D [22] 20 [24] 25 [26 [27] 20 [26 [27] 25 [27] 24 [27] 25 [27] 28 [27] 28 | <br> | | | | <del></del> | | | | <del> </del> | | | | | <del></del> | | | | | + | <del></del> | | | | ╂┙┷┺┷╛╁┖┵┵╂┶ | <u> </u> | | | | - | | <u> </u> | | | <del></del> | | <u> </u> | | | | <u> </u> | <u> </u> | | | | | | | | | | <del></del> | | , | | | | | | | | | | | | | | | | <u> </u> | | <br> | | | <u> </u> | <u> </u> | | | | <del></del> | <u> </u> | <br> | | | + | <del></del> | | | | <del> </del> | | | | | <del></del> | <u> </u> | | | | + | ******* | | | <del></del> | +++++++++++++++++++++++++++++++++++++++ | <del></del> | <u> </u> | # GROUP 8 RETURN JUMPS AND STOPS # GROUP 8 # RETURN JUMPS AND STOPS | 1. | Unconditional Stop/Return Jumps | RTJ/SRJ | |----|-------------------------------------|---------| | 2. | Selective Return Jumps | RJX | | 3. | A Return Jump | ARJ | | 4. | Q Return Jump | QRJ | | 5. | Selective Stops (with Return Jumps) | SRX | This group of instructions allows the programmer to stop the computer (if not illegal), and to transfer program control to a subroutine. It is important to note that the return jumps are not bank jump instructions in any way. The purpose of the bank term is to set or reset the Operand Bank setting only. The return jump is still within the same bank in which current program control is operating. Some of the return jumps and stops are conditional. They are conditioned by the contents of A, the contents of Q, the Jump switches, and the Stop switches. # The UNCONDITIONAL STOP/RETURN JUMP Instructions The RETURN JUMP instruction is an instruction that transfers program control to another point within the program. However, at that point is placed an address, such that the address forms a return path to the main program. The point to which control is transferred is a 15-bit address $\underline{M}$ where $\underline{M}$ = $\underline{m}$ + ( $V^V$ ) in the same bank that the program is operating, i.e., this is <u>not</u> a bank jump instruction. However, execution does not start with the upper instruction at $\underline{M}$ . Instead, (P) + 1 are placed in the upper address portion of the memory word. Execution then begins with the lower instruction of the memory word. The bank term $\underline{a}$ determines the value of the operand bank setting. If it is not used, the current operand bank setting remains. If it is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. The STOP/RETURN JUMP instruction is an instruction that unconditionally stops the computer. When the computer is restarted, program control transfers to another point within the program. However, at that point is placed an address, such that the address forms a return path to the main program. The STOP/RETURN JUMP instruction then follows the same form as the RETURN JUMP instruction (paragraphs 2 and 3 above). Do an Unconditional Return Jump to address SUB. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | $R_iT_iJ_i$ | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 27 27 28 29 30 31 32 33 34 35 13 | 16 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Do an Unconditional Return Jump to an address specified in Index Register 1. #### SOLUTION: | LOCN | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------|----------------------------------|-----------------------------------------| | | RIJ | <b>1</b> | 1 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 (0 ) | 20 21 22 23 24 25 26 27 28 29 30 | )<br> | # PROBLEM: Do an Unconditional Return Jump to address SUB modified by Index Register 2. The routine SUB is to call operands from Bank 6. #### SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------| | | RTJ | | | 1 2 3 4 5 6 7 8 | 9 10[11 [12]13[14]15[16]17[18]19[20[21]22[23[24]25[26[27]28[29]30[31]32[33[34]35[36] | 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: Stop the computer. When restarted, do a Return Jump to address ROUTINE. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------|-------------------------------------------------------| | | SRJ ROUTINE | 1 | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 (0.14 (12.13.14.115.116.117.118.119.12012.1122123.124125126.127128129130.131.132(33.13413 | j<br>35136137138:3914014:1421431441451461471481491501 | #### The SELECTIVE RETURN JUMP Instructions The SELECTIVE RETURN JUMP instructions are conditional return jump instructions that test the three jump switches on the console to see if they are ON or OFF. There is one return jump instruction for each switch. If the jump switch is ON, program control transfers to a 15-bit address $\underline{M}$ where $\underline{M}$ = $m + (V^V)$ in the same bank that the program is operating, i.e., this is <u>not</u> a bank jump instruction. However, execution does not start with the upper instruction at $\underline{M}$ . Instead, $\underline{(P)} + 1$ are placed in the upper address portion of the memory word. Execution then begins with the lower instruction of the memory word. If the jump switch is OFF, program control continues executing in its normal sequence with no jump being made. The bank term $\underline{a}$ determines the value of the operand bank setting. If it is not used, the current operand bank setting remains. If it is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. Check Jump Switch 1. If it is ON, do a Return Jump to address PETE. If it is OFF, continue the program. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | | R.J.1 | ! ] ] ] ] ] ] ] ] | | 1 2 3 4 5 6 7 8 | <br> 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 | 13413513613713813914014.142143144145146147140.49150. | # PROBLEM: Check Jump Switch 2. If it is ON, do a Return Jump to address JOE modified by Index Register 2. If it is OFF, continue the program. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|--------------------------------------------------------------------------|----------------------------------------------| | | $RJ2$ $J\emptyset E 22$ | | | 1 2 3 4 5 6 7 8 | 9 .0 1.1 1.5 1.9 1.4 1.5 1.6 1.7 1.0 1.0 1.0 1.0 1.0 1.0 1.0 1.0 1.0 1.0 | 36 37 38 39 40 4 42 43 44 45:46 47 48 49 50 | # PROBLEM: Check Jump Switch 3. If it is ON, do a Return Jump to the address specified in Index Register 4. If it is OFF, continue the program. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------------|----------| | | R,J,3, , , , , , , , , , , , , , , , , , | | | 1 2 3 4 5 6 7 8 | | <br> | # PROBLEM: Check Jump Switch 2. If it is ON, do a Return Jump to address BILL where it is to pick up operands from Bank 3. If it is OFF, continue the program. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------------|------------------------------------------------------------------------|-----------------------------------------------------| | | $RJ_2$ $(3)BILL$ | | | . 12 13 14 15 16 17 1 | 8 a 10 11 15 15 14 15 16 15 15 15 15 15 15 | 34[35[36[37]38]39[40]4 [42[43]44]45[46[47]48[49[50] | # The A RETURN JUMP Instruction The A RETURN JUMP instruction is a conditional jump instruction that tests the contents of A for zero, non-zero, positive, or negative. One modifier must be specified. If the condition tested is true, program control transfers to a 15-bit address $\underline{M}$ where $M = m + (V^V)$ in the same bank that the program is operating, i.e., this is <u>not</u> a bank jump instruction. However, execution does not start with the upper instruction at M. Instead, (P) + 1 are placed in the upper address portion of the memory word and execution then begins with the lower instruction of the memory word. If the condition tested is not true, program control continues executing in its normal sequence with no jump being made. The bank term <u>a</u> determines the value of the operand bank setting. If it is not used, the current operand bank setting remains. If it is used, the current operand bank setting will be replaced by the value <u>a</u>. In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. A Return Jump is to be taken to address TOM if A is zero. If not, continue the program. What instruction will do this? # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------| | | A.R.J., Z.R. T.MM | i | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 37 138 139 140 14 142 143 144 145 145 145 145 | # PROBLEM: Do a Return Jump to address ROOT if A is positive. If A is negative, continue the program. # SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------|----------| | | $ARJ_{2}PL$ $RPPT$ | | | 1 2 3 4 5 6 7 8 | | 1 | # PROBLEM: Do a Return Jump to address ANS modified by Index Register 3 if A is negative. If A is positive, continue the program. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |---------------|--------------------------------------|--------------------------------------------------| | | $A_1R_1J_1, M_1I_1$ $A_1N_1S_1, J_1$ | | | 1 2 3 4 5 6 7 | | 4 35 36 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | # PROBLEM: Do a Return Jump to the address specified in Index Register 4 if A is non-zero. If A is zero, continue the program. | LOCN | OPERATION.MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|-----------------------------------------------------------------------------------|---------------------------------------------| | 4 1 1 1 1 1 | ARJ, NZ | | | 1 2 3 4 5 6 7 8 | 9 10 1-1-1213, 41/5 1-61/718 1912012112212312412512612712812913013/13213313413513 | 6137138:3914014 142:43:44:45:46:47:48 49:53 | # The Q RETURN JUMP Instruction The Q RETURN JUMP instruction is a conditional jump instruction that tests the contents of Q for zero, non-zero, positive, or negative. One modifier must be specified. If the condition tested is true, program control transfers to a 15-bit address $\underline{M}$ where $M = m + (V^V)$ in the same bank that the program is operating, i.e., this is <u>not</u> a bank jump instruction. However, execution does not start with the upper instruction at M. Instead, (P) + 1 are placed in the upper address portion of the memory word and execution then begins with the lower instruction of the memory word. If the condition tested is not true, program control continues executing in its normal sequence with no jump being made. The bank term <u>a</u> determines the value of the operand bank setting. If it is not used, the current operand bank setting remains. If it is used, the current operand bank setting will be replaced by the value <u>a</u>. In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. A Return Jump is to be taken to address HODGE if Q is zero. If not, continue the program. What instruction will do this? #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------| | | QIRJ ZIR HODGE | 1 | | : [2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 21 122 123 124 125 126 127 128 129 130 131 132 133 134 135 131 | 61371381391401411421431441451461471481491501 | #### PROBLEM: Do a Return Jump to address PODGE if Q is negative. If Q is positive, continue the program. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | | QRJ,MI PØDGE | | | 1 2 3 4 5 6 7 8 | 9 (0 111 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Do a Return Jump to address SMODGE modified by Index Register 1 if Q is positive. If Q is negative, continue the program. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|-----------------------------------------------| | | QIRJ. PL SMODGE 1 | | | 1 2 3 4 5 6 7 8 | | 136 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Do a Return Jump to the address specified in Index Register 5 if Q is non-zero. If Q is zero, continue the program. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------|----------------------------------------------------------------------| | | Q.R.J., N.Z. | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 137 38 39 40 4. 42 43 44 45 46 47 48 49 50 | # The SELECTIVE STOP/RETURN JUMP Instructions The SELECTIVE STOP/RETURN JUMP instructions are conditional stop instructions that test the three stop switches to see if they are ON or OFF. There is one stop instruction for each switch. If the stop switch is ON, the computer will stop. When the computer is restarted, program control will transfer to a 15-bit address $\underline{M}$ where $\underline{M} = m + (V^V)$ in the same bank that the program is operating, i.e., this is <u>not</u> a bank jump instruction. However, execution does not start with the upper instruction at $\underline{M}$ . Instead (P) + 1 are placed in the upper address portion of the memory word. Execution then begins with the lower instruction of the memory word. If the stop switch is OFF, the computer will not stop and the return jump will still be made. The bank term $\underline{a}$ determines the value of the operand bank setting. If it is not used, the current operand bank setting remains. If it is used, the current operand bank setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. Check Stop Switch 1. If it is ON, stop the computer. If it is OFF, do not stop the computer. In either case do a Return Jump to address SNOPS. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|---------------------------------------------------| | | $S_1R_1$ , $S_1N_1\phi_1P_1S_1$ | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | <br> | 4 35 36 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Check Stop Switch 2. If it is ON, stop the computer. If it is OFF, do not stop the computer. In either case do a Return Jump to address POPS modified by Index Register 2. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------|----------| | | $S_1R_12$ $P_1\phi_1P_1S_1$ , $P_2$ | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 220 221 222 23 224 225 26 27 28 229 320 31 32 2 33 | | #### PROBLEM: Check Stop Switch 3. If it is ON, stop the computer. If it is OFF, do not stop the computer. In either case do a Return Jump to the address specified in Index Register 1. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------| | | S <sub>1</sub> R <sub>1</sub> 3 <sub>1</sub> 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 31 | 8 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: Check Stop Switch 2. If it is ON, stop the computer. If it is OFF, do not stop the computer. In either case do a Return Jump to address SPOTS modified by Index Register 2 and set the Operand Bank setting to Bank 1. | LOCN | | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------| | | | S.R.2 | | | 1 2 3 4 5 6 7 6 | 9 | 10 11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 3 | 39 40 4+ 42 43 44 45 46 47 48 49 50 | #### NEW CONCEPTS OF GROUP 8 When we introduce return jump instructions, we normally refer to them as being used in "subroutines" of the subprogram. A subroutine is a short routine within the subprogram that is entered from the main routine, calculates answers from data set up by the main routine, and returns control back to the main routine at exactly the point from which it left. A subroutine may be entered from various places of the main routine. Each time new data could be processed, new answers calculated, and always a return to the main routine to the point that it left off. Let's discuss in general what happens when a "return jump" instruction takes place, how program control enters the subroutine, and how a return is made back to the main routine. Assume a return jump to address SUB as shown: | LOCATION | OCCUATION MODELLE | C ADDRESS FIELD | | |--------------------|-----------------------------------------|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LUCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | | 112121412141714 | • **************** | [20] <u>[27] [27] [27] [28] [28] [28] [28] [28] [28] [28] [28</u> | 41 (42 (43 (44 (45 ) M (47 ) 46 (49 ) 50 (51 ) 52 (53 ) 54 (56 ) 56 (57 ) 56 (56 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 56 (57 ) 5 | | L | IDENT | EXAMPLE | | | | - | | <del></del> | | | | <del></del> | | | | 1 | | | | P | 10-1-1-1-1 | | | | F | RTJ | 54B | | | | | <u> </u> | | | | • • • • • • • • • • • • • • • • • • • • | <u> </u> | | | 1 1 1 1 1 1 | <u> </u> | | | | 1 | • | | <del></del> | | | | | <del>────────────────────────────────────</del> | | 548 | RIT! | ** | ENTONICE TO CHOOK SE | | | | SAVE | ENTRANCE TO SUBROUTINE | | | PVM | 2AVG IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII | | | | <del>-</del> | | <u> </u> | | | 1-1-1-1 | <u> </u> | | | | 54J | 54.8 | EXIT FROM SUBROUTINE | | | <u> </u> | <u> </u> | | | | <b>!</b> | | | | | • | | | | | END | <u> </u> | | | <del>┠╵╸</del> ┶╌┼ | MU IIII | <del></del> | <del></del> | When the return jump is executed at address P, the 15 bit address, P+1, is automatically stored in place of \*\* at address SUB by the hardware. The SLJ function code remains. If this instruction is ever executed, note how program control could return to address P+1. The first instruction executed in the subroutine is not the SLJ but the STA. When the subroutine is finished, a jump is made to the entry address (SUB). The SLJ is then actually executed and the return is made to the main routine. If later in the main routine, let's say at address PX, another return jump is made to SUB, address PX+1 will automatically be stored in place of \*\*. From this you can see that a subroutine can be used at any point in the main routine and a return will be made to the correct address. Care must be taken if the return jump instruction is an upper instruction. Since P+1 is automatically stored, a return will miss the execution of the lower instruction. For this reason the next instruction is usually forced upper (+ or symbol) or the return jump instruction is forced lower (-). # Problem 8: A subroutine is to be written so that, when entered at any time, will determine the largest of three unequal operands. Assume the three operands to be stored at addresses A, B, and C and store the maximum operand at address MAXF. # Flowchart: #### MAXIMIZE SUBR Problem 8 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIE | RS ADDRESS FIELD | COMMENTS | |-----------------------------------------|------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 2 : 2 4 5 4 7 4 | | <br> | <br> | | | IDENT<br>ENTRY | MAXIMIZE | | | 1 1 1 1 1 1 | ENTRY | MAXIMIZE | <u> </u> | | MAXF | BSS | 12, , , , , , , , , , , , , , , , , , , | | | MAXIMIZE | BSS | 12 | <u> </u> | | <u> </u> | <u> </u> | <u> </u> | | | 11. | <u> </u> | <u> </u> | <u> </u> | | | <u> </u> | | | | | RTJ | SubR | <u> </u> | | | <u> </u> | <u> </u> | <u> </u> | | | <u> </u> | <u> </u> | <u> </u> | | | <u> </u> | <u> </u> | <u> </u> | | | SLJ | MAXIMIZE | <u> </u> | | 5UBR | 845 | ** | ENTRANCE TO SUBROUTINE | | · | LDA | A | | | | 34B | BANDG | <u> </u> | | | AJP, PL | AANDG | AG.TB | | | LDA | B | <u> </u> | | 111111 | SUB<br>AJP, PL<br>LDA<br>STA | C<br>TRANSB | | | | AJP, PL | TRAUSB | B.GT.C | | TRANSC | LDA | <b>C</b> | | | | \$TA. | MAXE | | | | 5.LJ | SUBR | EXIT SUBR OUT INE | | TRANSB | LDA | <b>B</b> | <u> </u> | | 44444 | STA<br>SLT | MAXE | 1 | | 4-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1 | | SUBR | EXIT SUBROUTINE | | AANDC | LDA | <i>A</i> | | | | 34B | | | | | AJP, PL | TRANSA | 4-GT-C | | | 347 | TRANSC | | | TRANSA | KDA | <u> </u> | | | | STA | MAXE<br>SUBR | Transfer of the state st | | | SLJ<br>END | Subk | EXIT SUBROUTINE | | | END | <u> </u> | | | | | | <u>L </u> | Somewhere within this subprogram would also be included the symbols A, B, and C in the location field with a declaration of the prestored data or the area reserved. # Student Problem 8A: Solve problem 8 finding the smallest operand. Store at address MINF. Flowchart: # Problem 8A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |------------------------|---------------------------------------------------|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 12 12 14 15 14 17 18 | այլացի որվան կանված ված գանգանի անգանական կա | | 41.47 (\$1.66) 63 (\$1.47 (\$4.47) \$2 (\$1.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$5.50 (\$ | | | <u> </u> | <br><u> </u> | | | 1::::: | | <u> </u> | | | | | | | | <u> </u> | | | <u> </u> | | | | <u> </u> | | | | | | | | | 4 | | <u> </u> | | | <del> </del> | | <u> </u> | | | <del> </del> | <u> </u> | <u> </u> | | | | <u> </u> | <u> </u> | | | | <u> </u> | <u> </u> | | | <del> </del> | <u> </u> | | | | | | <u> </u> | | | | | | | | | <u> </u> | | | | | | | | | | | | | | | | | | | | <u> </u><br><u> </u> | <u> </u> | | | | <u> </u> | | | | | <u> </u> | | | | 1 1 1 1 1 1 1 1 1 1 1 1 | <u> </u> | <u> </u> | | | | <u> </u> | | | | | | | | | | | | | | | <u> </u> | <u> </u> | | | | <u> </u> | <u> </u> | | | <u> </u> | <u> </u> | | | | | <u> </u> | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 111111 | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | <u> </u> | | | | . <u></u><br> | | | | | <u> </u> | | | المسلسلين فالمسلسل | | | | # GROUP 9 # REGISTER JUMPS #### GROUP 9 ## REGISTER JUMPS | 1. | Register Jump | RGJP | |----|-------------------|------| | 2. | Non-zero Bit Jump | NBJP | | 3. | Zero Bit Jump | ZBJP | This group of instructions consists of conditional jumps, conditioned on the contents of any operational register. If the jump condition is satisfied, a jump is taken. If the condition is not satisfied, the program continues. The first instruction tests any operational register for some relation to a given value. This relation can be one of many used in pure and applied mathematics. The other two instructions test any bit in any operational register for being in the set ("1") or clear ("0") state. They commonly answer the "yes or no" or "true or false" questions. # The REGISTER JUMP Instruction The REGISTER JUMP instruction is an instruction that compares the 15-bit value $\underline{y}$ with the contents of any specified register. The designator $\underline{p}$ specifies the register compared. No memory reference is made. There are eight possible comparisons that can be made. One of the modifiers must be specified. They are as follows: | Мо | difier | Comparison | |----|--------|------------------------------------------| | 1. | EQ | Contents of p equal to y | | 2. | GT | Contents of p greater than y | | 3. | LT | Contents of p <u>less than</u> y | | 4. | NE | Contents of p not equal to y | | 5. | LE | Contents of p less than or equal to y | | 6. | GE | Contents of p greater than or equal to y | | 7. | LT,D | Contents of p less than y | | 8. | GE,D | Contents of p greater than or equal to y | If the comparison is true, program control transfers to a 15-bit address $\underline{M}$ where $\underline{M}$ = $\underline{m}$ + ( $\underline{B}^b$ ). If the comparison is not true, program control continues to the next instruction. In either case all registers are left unchanged, except for the possibility of the last two modifiers being used. With respect to the last two modifiers additional features are incorporated. When the comparison is made, and it is found that the contents of p are less than y, the contents of p are decremented by the operand y before going on to the next instruction. Check to see if the A register contains 33 octal. If it is, jump to address ENDCARD. If not, continue the program. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------|--------------------------------------------------------------------------------------------------------------------------------------------------|----------| | | RGJP, EQ A, 33B, ENDCARD | | | 2 3 4 5 6 | 6, 7, 8, 9, 0, 0, 1, 12, 13, 4, 5, 16, 12, 18, 19, 10, 12, 122, 23, 125, 26, 27, 28, 29, 20, 37, 32, 134, 137, 137, 137, 137, 137, 137, 137, 137 | | #### PROBLEM: Check to see if the D register contains 100. If yes, jump to address GETUPP modified by Index Register 4. If no, continue the program. ## SOLUTION: | LOCN | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|----------------------|-----------------|--------------------------------------------------------------------| | | RGJP, EQ | D, 100, 6, E, T | $U_1P_1P_1$ , $Y_1$ | | 2 3 4 5 6 7 8 5 | 1 | | [29]30[31]32[33]34[35]36;37[38]39]45]4 42[43]44 45 46 47 48 49]50; | ## PROBLEM: Examine the contents of the A register. If less than or equal to nine, jump to address NUM. If greater than nine, continue the program. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|--------------------------------------------------------------------------|----------| | | $RGJP_{g}LE$ , $A_{g}g_{g}NUM$ | ! | | 1 2 3 4 5 6 7 8 | 9 .0[ .5].5].6[.5].6[.7].8].9.[20]5. 22]23[24]25[26]27[28[29]30[31]32[33 | | # PROBLEM: Examine the contents of the Q register. If greater than or equal to 50, jump to address OVER. If not, continue the program. | LOCM | OPERATION MODIFIERS ADDRESS FIELD | COMMENTS | |---------------|-----------------------------------|----------| | | $RGJP, GE$ $Q_1, 50, \phi_1 V ER$ | | | 1 2 3 4 5 6 7 | | <br> | # The NON-ZERO BIT JUMP Instruction The NON-ZERO BIT JUMP instruction is an instruction that tests for a non-zero bit at any specified bit position, designated by g, in any specified register, designated by p. No memory reference is made. If the specified bit is in the set state (binary 1), program control transfers to a 15-bit address $\underline{M}$ where $\underline{M} = m + (\underline{B}^b)$ . If the specified bit is in the clear state (binary 0), program control continues to the next instruction. In either case, unless a modifier is used, the bit is left unchanged. There are three modifier options available that could change the bit <u>after</u> the type of exit has been determined. They are ST, CL, and CM. ST means that the bit is to be set as the exit is taken. CL means that the bit is to be cleared as the exit is taken. CM means that the bit is to be complemented as the exit is taken. Examine bit 46 of the D register. If a "1", jump to address READO. If a "0", continue the program. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------|---------------------------------------| | | N.B.J.P. D. 46, R.E.ADO | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 10 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | 1391401411421431441451451471481491801 | ## PROBLEM: Examine bit 14 of Index Register 1. If a "1", jump to address WRITEON1. If a "0", continue the program. In either case clear the bit after it has been examined. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------| | | N.B.J.P. 3 C.L. B.1 3 1 4 3 W.R.I.T.E. 6 N.1 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 5137 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Examine bit 10 of the Q register. If a "1", jump to address SWITCH modified by Index Register 3. If a "0", continue the program. In either case complement the bit after examining it ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------|------------------------------------------| | | $N_i B_j J_i P_{i,j} C_i M_i$ $Q_{i,j} I_j D_{i,j} S_i W_i I_i T_i C_i H_i$ | 1 | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12]13 [14]15 [16]17 [16 [19]20[21]22[23[24]25[26]27[20]29[30[31]32[33]34[35]36[37 | 138139140141142143144145146147148149150; | #### PROBLEM: Set bit 5 of the Interrupt Mask register and continue the program. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------------------|------------------------------------------------------------------------------------|-------------------------------------------------| | | $N_{1}B_{1}J_{1}P_{1}S_{1}T_{1}$ $IM_{1}S_{1}X_{1}+I$ | | | 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 324 125 26 127 128 129 30 13 132 33 34 | 35136137138139160141142163144145145147148149150 | #### The ZERO BIT JUMP Instruction The ZERO BIT JUMP instruction is an instruction that tests for a zero bit at any specified bit position, designated by g, in any specified register, designated by p. No memory reference is made. If the specified bit is in the clear state (binary 0), program control transfers to a 15-bit address $\underline{M}$ where $\underline{M}=\underline{m}+(\underline{B}^b)$ . If the specified bit is in the Set state (binary 1), program control continues to the next instruction. In either case, unless a modifier is used, the bit is left unchanged. There are three modifier options available that could change the bit <u>after</u> the type of exit has been determined. They ST, CL, and CM. ST means that the bit is to be set as the exit is taken. CL means that the bit is to be cleared as the exit is taken. CM means that the bit is to be complemented as the exit is taken. Examine bit 23 of the A register. If a "0", jump to address LOWERPT. If a "1", continue the program. ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|----------| | | $ZBJP$ $A_{2}23.LØWERPT$ | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | | ## PROBLEM: Examine bit 39 of the D register. If a "0", jump to address NEXTPARAM modified by Index Register 4. If a "1", continue the program. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------|----------| | | ZBJP | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 112 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | | # PROBLEM: Examine bit 13 of Index Register 3. If a "0", jump to address PARERROR. If a "1", continue the program. In either case clear the bit after examining it. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------|----------| | | ZBJP, CL, B3, 13, PARERRAR | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 3 | | ## PROBLEM: Set bit 1 of the A register and continue the program. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | $Z_1B_1J_1P_{1,1}S_1J_1$ | | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12 [13 ]14 [15 [16 [17 ]18 [19 [20 [21 ]22 [23 [24 [25 [26 [27 ]28 [29 ]30 [31 ]32 ]33 ]34 ]35 [36 [37 | 7 38 39 40 41 42 43 44 45 46 47 48 49 50 | | | - | | | |----|---|---|--| | | | | | | •, | | | | | | | | | | | - | | | | | | | | | | | - | | | | | | | ## NEW CONCEPTS OF GROUP 9 The three instructions in this group check a bit or a quantity in a register. Any operational register can be checked. This includes A, Q, B1-B6, D, P, and bank registers. Since no memory reference is made, these are termed fast instructions. ## Problem 9: A table of 100 random integers ranging from -100 to +100 is in memory starting at address FLUX. Write a subprogram that will pick out all integers between but not including -5 and +5. Store them beginning at address RANGE. ## Flowchart: Problem 9 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIES | S ADDRESS FIELD | COMMENTS | |---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------------------------------------| | 11111111111111111 | * 10 13 12 13 24 15 34 17 38 19 | <br> 20 21 27 23 24 25 24 27 28 28 31 25 15 24 27 28 28 28 | <br> | | 11111111111111111 | TOENT | SEPARATE | <u> </u> | | | ENTRY | SEPARATE | | | RANGE | BSS | 100 | | | EPARATE | 8,S,S | 11, | <u> </u> | | | ENI | 0,1 | | | | ENI | 0,2: | | | EXTWORD | LDA | FLUX, 1 | | | المستناب المستناب | | A3-53LT | Num-675 | | Kent | A CONTRACTOR OF THE PARTY TH | 99,1 | WP. J. E | | حلم ف ف ف المراب ف المراب | SLJ | WEXTWORD | | | | 545 | SEPARATE | 1-71-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1- | | LT | RGJP, LT | A, 5, ENT | Wym-47-5 | | | SLJ | CKCNT | NO2-GE. | | ENT | STA | RANGE , 2 | | | | FNI | 11,2 | <u> </u> | | | BLJ | CKENT | | | | END | <u> </u> | <u> </u> | Somewhere within this subprogram would also be included the symbol FLUX in the location field with a declaration of the prestored data or area reserved. # Student Problem 9A: Solve problem 9 by using the instruction LDA, CM. Also see if you can shorten the number of instructions used to solve the problem. Flowchart: Problem 9A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | S ADDRESS FIELD | COMMENTS | |---------------------------------------------------|----------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------| | | 10 ( ) ) ( 17 ( 18 ( 14 ) 15 ( 14 ) 17 ( 18 ( 18 ) | 0 j2, 172 j26 j26 j25 j36 j27 j26 j29 j30 j21 j32 j35 j44 j35 j56 j37 j36 j27 j46 | 41 (42 43 44 45 44 47 44 48 58 51 52 54 55 54 57 58 58 58 58 58 58 58 | | | | <u> </u> | | | | | <u> </u> | | | <del> </del> | 1 | | | | | <del> </del> | <u> </u> | | | | 1 1 | <del> </del> | | | <del></del> | 1 | <del>ļā 1 4 4 1 4 1 1 1 1 1 1 1 1 1 1 1 1 1 1 </del> | | | | | | | | | | | | | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | <u> </u> | <u> </u> | | | | | <del> </del> | | | | | <del></del> | 111111111111111111111111111111111111111 | | | <del> </del> | <u> </u> | | | | | | | | <del></del> | | <del></del> | | | | 1 | i i | <del></del> | | | <del> </del> | <del> </del> | <u> </u> | GROUP 10 BANK JUMPS #### GROUP 10 ## BANK JUMPS | 1. | Execute | EXEC | |----|-------------------------|-----------------------| | 2. | Unconditional Bank Jump | UBJP | | 3. | Bank Jump Lower | $\operatorname{BJPL}$ | | 4. | Bank Return Jump | BRTJ | | 5. | Bank Jump and Set Index | BJSX | This group of instructions is the only group that has the ability to transfer program control to another bank. The first instruction allows a maximum of two instructions to be executed from another bank. The second instruction transfers program control unconditionally to another bank. The third instruction is the only instruction that will transfer program control to the lower instruction in another bank or within the same bank. The last two are both bank return jumps; however, the last one allows the programmer to easily place parameters in a subroutine. #### The EXECUTE Instruction The EXECUTE instruction is an instruction that executes one 48-bit or two 24-bit instructions at an address $\underline{M}$ where $\underline{M}$ = $\underline{m}$ + ( $\underline{B}^b$ ) + ( $\underline{V}^V$ ). If the bank term $\underline{a}$ is used, the operand bank setting is replaced by the value $\underline{a}$ . If the bank term is not used, the operand bank setting remains. The Instruction Bank Register and the P Register do not change for this instruction even though program control "seems" to transfer to address M. The instruction(s) are at address M in the bank specified by the operand bank setting. This is the only exception to the normal rules for the instruction bank setting and the operand bank setting. After the instruction(s) are executed, program control resumes at (P) + 1 which is the instruction immediately following the EXECUTE instruction. Execute a pair of instructions at address SOPTS. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | EXEC | | | 1 2 3 4 5 6 7 8 | 9 10 [11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 3 | 16 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Execute a pair of instructions at the address specified in Index Register 1. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | | EXEC | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 | 14: 142 43 44 45 46 47 48 49 50 | ## PROBLEM: Execute a 48-bit instruction at address TAB modified by Index Register 2. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------| | | EXEC TABO2 | | | 1 [2 3 4 5 6 7 6 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 34 | 11391401411421431441451461471481491501 | #### PROBLEM: Execute a pair of instructions at address PUDGE in the bank that PUDGE resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | | EXEC (#) PUDGE | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 22 24 25 26 27 28 29 30 31 32 33 34 3 | 51364371384391401411421431441451461471481491501 | ## The UNCONDITIONAL BANK JUMP Instruction The UNCONDITIONAL BANK JUMP instruction is an instruction that transfers program control to a 15-bit address in bank $\underline{i}$ (within parentheses). The jump address is $\underline{M}$ where $\underline{M}$ = $\underline{m}$ + ( $\underline{B}^b$ ). As the jump takes place, the instruction bank setting is replaced by the value $\underline{i}$ and the operand bank setting is replaced by the value $\underline{a}$ . Do a bank jump to Bank 2 address TAX and set the Operand Bank setting to Bank 1. #### SOLUTION: | LOCN | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------|----------------------------|------------------------------------------------------------------------| | | $U_1\mathcal{B}_1\mathcal{J}_1\mathcal{P}_1$ | (12) TAX, 1, 1, 1 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 | 20 21 22 23 24 25 26 27 28 | <br> 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: Do a bank jump to Bank 2 address TAX modified by Index Register 1 and set the Operand Bank setting to Bank 1. #### SOLUTION: | LOCN | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------|---------------|---------------------------------------------------------------------------------------------------| | | UBJP | (2)TAX,1,1 | 1<br>1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 [12 13 14 15 16 17 18 19 | | 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Do a bank jump to address TEST in the bank where TEST resides and switch the Operand Bank setting to the bank where the UBJP resides. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | U(B,T,P) $T(E,S,T)$ | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 3 1 32 3 3 3 4 3 5 1 | 36 37 38 39 40 4 42 41 44 45 47 48 49 47 | ## PROBLEM: Do a bank jump to address SMOKES in Bank 2 modified by Index Register 5 and set the Operand Bank setting to Bank 3. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|--------------------------------------------------------------------------------------------------------|-----------------------------------------------------| | | U.B.J.P. (2) S.M.B.K.E.S. 5523 | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 21 122 23 24 125 126 127 128 129 130 31 132 133 134 135 | ,<br>5 36 37 38 39 40 4- 42 43 44 45 46 47 48 49 50 | #### The BANK JUMP LOWER Instruction The BANK JUMP LOWER instruction is an instruction that unconditionally transfers program control to the lower instruction of a memory word. It is the only instruction in the 3600 repertoire of instructions that will jump to the lower instruction of a memory word. The jump is to a 15-bit address $\underline{M}$ where $\underline{M} = m + (\underline{B}^b)$ in bank $\underline{i}$ . As the jump takes place, the instruction bank setting is replaced by the value $\underline{i}$ and the operand bank setting is replaced by the value $\underline{a}$ . If the bank terms are not specified by the programmer, the current bank settings will remain unchanged. Jump to the lower instruction at address DAVESS. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------| | | BJPL | | | 1 2 3 4 5 6 7 6 | <br> 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 37 38 39 40 41 142 43 44 45 46 47 48 49 50 | #### PROBLEM: Jump to the lower instruction at the address specified in Index Register 3. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------| | | BJPL | | | 1 12 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 20 21 [22] 23] 24[25] 26 [27] 28 [29] 30 [31 [32] 33 [34] 35 | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Jump to the lower instruction at address DAMAN in the bank where DAMAN resides and set the Operand Bank to Bank 2. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------| | | BJPL (\$) DAMAN, | | | 1 2 3 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 19 120 21 22 23 24 25 26 27 28 29 30 31 32 33 34 32 | 5[36[37]38]39[40]4:[42]43[44]45[46]47;46:49[50 | # PROBLEM: Jump to the lower instruction at address PETE in the bank where PETE resides and set the Operand Bank to the bank where the BJPL resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------|------------------------------------|-------------------------------------------------| | | B,J,P,L (#),P,E,T,E,,,,* | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 | | 313613713813914014.142143144145146147148.49150; | # The BANK RETURN JUMP Instruction The BANK RETURN JUMP instruction is an instruction that unconditionally transfers program control to the upper instruction at address $\underline{M+1}$ where $\underline{M}=\underline{m}+(\underline{B}^b)$ in bank $\underline{i}$ and sets the operand bank to the value $\underline{a}$ . The hardware places (at address M) a "return" instruction such that, when executed, will return control to the upper instruction immediately following the BANK RETURN JUMP instruction. The instruction placed at M is an UNCONDITIONAL BANK JUMP to (P) + 1 which will also return the two bank registers to the state they were in before the BANK RETURN JUMP was executed. Do a Bank Return Jump to address FOX in Bank 1 and set the Operand Bank to Bank 2. #### SOLUTION: | LOCN | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------|----------------------------------|----------| | | $B_{1}R_{1}T_{1}J_{1}$ | $(1)$ $F \phi x 2 2 2$ | | | 1 2 3 4 5 6 7 8 | 9 10 [11 ]12 [13 ]14 [15 ]16 [17]18 [19 [2 | 0[21]22]23 24 25 2 : 27 28 29 30 | <br> | #### PROBLEM: Do a Bank Return Jump to address FOX modified by Index Register 2 in Bank 1 and set the Operand Bank to Bank 3. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------------------------------------|----------| | | BRTJ | | | 1 2 3 4 5 6 7 6 | 9 10[11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | | ## PROBLEM: Do a Bank Return Jump to address SQRTF in the bank where SQRTF resides and set the Operand Bank to the bank in which the BRTJ resides. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------|----------| | | BRTJ (#)SQRTF22* | | | 1 2 3 4 5 6 7 8 | 9 10[11 [12]13]14[15]16[17]16[19]20[21[22]23]24[25]26[27[28]29]30[31]32[33]34[35]36 | | #### PROBLEM: Do a Bank Return Jump to address TAB modified by Index Register 1 in the bank where TAB resides and set the Operand Bank to the bank in which the BRTJ resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------|-------------------------------------------------| | | $B_{i}R_{i}T_{i}J_{i}$ $(\#)_{i}T_{i}A_{i}B_{i}$ $\downarrow 1$ | | | 1 2 3 4 5 6 7 8 | 9 10]11 [12]13]14 [15]16[17]18 [19]20[21[22]23[24]25[26]27[28]29[30[31]32[33]34] | 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### The BANK JUMP AND SET INDEX Instruction The BANK JUMP AND SET INDEX instruction is an instruction that unconditionally transfers program control to the upper instruction at address $\underline{m+1}$ in bank $\underline{i}$ and sets the operand bank to the initial value of the instruction bank. The hardware places (at address m) a "return" instruction such that, when executed, will return control to the upper instruction somewhere following the BANK JUMP AND SET INDEX instruction. To explain this, the sequence of operations by the hardware is very important. - 1. UBJP $(IB_i)0$ , b, $OB_i$ is placed at address m. The index designator is the same one specified in the instruction. - 2. The contents of the P register are placed in the specified index register. - 3. The initial instruction bank setting is placed in the operand bank. - 4. The instruction bank setting is replaced by the value i. - 5. Program control goes to m + 1 in bank <u>i</u>. This then is a BANK RETURN JUMP with the added features. - 1. The operands used by the subroutine will be in the bank of the main routine, usually following immediately the BANK JUMP AND SET INDEX instruction. - 2. Before returning to the main routine, if the programmer increments the contents of the specified index register by 1 more than the number of operand addresses used, he can jump "around" his data and his program will continue with his next executable instruction. Do a Bank Jump and Set Index to address PETE in Bank 2. Contain the present address of this instruction in Index Register 3. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------------------------|------------------------------------|------------------------------------------------| | | BJSX (2) PETE, 3 | | | 1 2 3 4 5 6 7 8 9 | | 5 36 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | # PROBLEM: Do a Bank Jump and Set Index to address TOM in the bank where TOM resides and use Index Register 2 for retaining the address of the BJSX instruction. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|----------------------------------------------------------------------------------------------------|---------------------------------------------| | | BJ5X (\$) T6M, 2 | 1 | | : [2 3 4 5 6 7 8 | 9 10 [11 [12]13 [14]15 [16 [17]18 [19 [20]21 [22]23 [24]25 [26 [27]28 [29 [30]31 [32 [33]34]35 [34 | 5 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Do a Bank Jump and Set Index to address JOE in Bank 4 and use Index Register 5 for retaining the address of the BJSX instruction. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------|----------| | | BJ5X (4) JØE,5 | | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12 [13 [14 [15 [16 [17]16 [19 [20]21]22 [23 [24 [25 [26 [27]28 [29]30 [31 [32 [33 ]34 ]35 [36 | <br> | #### PROBLEM: Do a Bank Jump and Set Index to address SUB in the bank where SUB resides. Index Register 6 is used for retaining the address of the BJSX instruction. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------| | | B.J.S.X. (#1) S.U.B., 6 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 120 21 122 23 24 25 26 27 28 29 30 31 32 33 34 35 | 36137138139140141142143144145146147(48149/50) | #### NEW CONCEPTS OF GROUP 10 The BANK JUMP instructions allow the programmer to transfer program control to any bank in a multi-bank system. If subprograms are self-contained in one bank, there is no need for the BANK JUMP instructions. At this time we do not want to become deeply involved with the use of these instructions. The reason is that we have not yet discussed the communication between subprograms in different banks. The concept of subprograms involving a multi-bank system will be discussed later in this section. The EXEC instruction is a quick and effective instruction to execute a short "subroutine" (two 24-bit instructions or one 48-bit instruction) without leaving main control. We can execute the instruction or instructions at the address specified by the EXEC instruction in any bank, and when they are finished, continue program control to the instruction following EXEC. The BJPL instruction is the only instruction that can jump to the lower instruction without changing the upper instruction. The jump can be made without changing banks by simply not specifying the bank terms. The BRTJ instruction allows subroutines, even subprograms, to be executed in another bank, and control returned to the bank of the calling subprogram automatically. When the BRTJ is executed to some address, execution starts at that address plus 1. At the address is placed a UBJP (48 bits) instruction, so that if it is ever executed a "return" will be made back to the instruction following the BRTJ. This is why each subprogram coded so far has contained a BSS 1 instruction at the entry point - so that the subprogram can be used as a subroutine, either by the monitor or by another subprogram. More will be said when we talk about subprograms. The BJSX instruction is very much like the BRTJ. The difference is that with the BJSX, the programmer can easily pass data to the subroutine. The data is stored immediately following the BJSX instruction. A sample of coding might look like the following: BJSX SUB, 1 DEC 58, -63, 5 \_ - Here, three parameters are to be picked up by SUB. When the BJSX instruction is executed, the address of the BJSX instruction enters the designated index register automatically (in this case $B^1$ ). With this address the subroutine SUB can reference the three operands. When the return is made, the subroutine must make sure that the data is bypassed when continuing the program. # Problem 10: Show how the BJSX instruction can be used to form Y = 3X-256943 in integer format. Flowchart: PASS Enter Form 3X - 256943 Store Result At Y Exit Problem 10 could be solved by coding in the following manner | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 112121412141714 | • • • • • • • • • • • • • • • • • • • | [20] [21] [22] [23] [24] [25] [26] [27] [25] [26] [26] [26] [25] [26] [26] [26] [27] [26] [27] | 1<br> | | | TOENT | PASS | | | | ENTRY | PASS | | | <u> </u> | | 1 | | | PASS | BSS | 1 | | | | <u> </u> | | | | | • | | | | | <u> </u> | <u> </u> | | | READY | BJSX | SUB,1 | | | | | 3,256943 | | | | | | The second secon | | | <u> </u> | | | | | <u> </u> | | | | SUB | 855 | 1 | | | | L.D.A. | X | | | | MUI | <i>I</i> , <i>1</i> , | ADDRESS READY +1 | | | 54B | | ADDRESS READY +2 | | | STA | 1 | | | 4.4.1.1.1.1 | INI | ${\it z}_{i}$ | BYPASS DATA | | | SLJ | SuB | | | | END | | recommendation of the control of the first of the control c | Somewhere within this subprogram would also be included the symbol ${\tt X}$ in the location field with a declaration of the prestored data or area reserved. # Student Problem 10A: Show how subroutine SUB would evaluate Y = 405X+356432 if the constants are passed from the main routine. Flowchart: # Problem 10A could be solved by coding in the following manner: | LOCATION | OPERATIO | N,MODIFIER | S ADDRESS FIELD | COMMENTS | |---------------------|--------------------|----------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------| | 1,213 613 6,7,3 | 9 10 11 117 111 19 | | 20 ; 21 ; 17 ] 23 24 25 26 27 26 26 36 43 27 28 28 28 27 38 39 40 | 0. (4) 40 (40 (41 (41 (41 (42 (41 (43 (42 (41 (41 (42 (41 (41 (41 (41 (41 (41 (41 (41 (41 (41 | | | | | | | | | | | | <u></u> | | | | 4444 | | <u> </u> | | | + | | | <u> </u> | | | | اللسلك | | | | <u> </u> | | احتصاب المساد | | <u> </u> | | | | المناسخ المسلمة | <u> </u> | <u> </u> | | | | 1-1-1-1-1 | | and the standard and the standard and a standard and a standard and a standard and a standard and a standard a | | | | <u>.iii</u> ! | <b>!</b> | <u> </u> | | | | | hadrade de d | | | | | | | | | | | | | | | | | alamida admi dan dan | | | | | | المال المال | <br> | 1<br>1 | | | | <u> </u> | <u> </u> | <u> </u> | | <u> </u> | | <u> </u> | <br> | | | | | 4-4-4-4 | | | | | | 1111 | والمراجة والمراجة والمراجة والمراجة والمراجة والمراجة والمراجة والمراجة والمراجة | | | | | سد ساسد دا | | | # GROUP 11 INTER-REGISTER #### GROUP 11 #### INTER-REGISTER | 1. | Register Operation | ROP | |----|--------------------|-----| | 2. | Register Swap | RSW | | 3. | Register Transmit | RXT | This group of instructions transmits the contents of operational registers with some operation possibly taking place. No memory reference is made. The first instruction specifies one of seven operations to take place between the contents of two registers, the result going to a third register. The last two perform no operation, but simply position the contents of registers for maximum speed and efficiency. # The REGISTER OPERATION Instruction The REGISTER OPERATION instruction is an instruction that performs one operation between two registers (source) and places the result in a third register (destination). No memory reference is made. The contents of the source registers are left unchanged. The contents of the destination register are replaced by the result of the operation. The operations allowable are: | 1. | OR | Inclusive OR | | |----|-----|-----------------|--| | 2. | XOR | Exclusive OR | | | 3. | AND | Logical Product | | | 4. | IMP | Implication | | | 5. | EQ | Equivalence | | | 6. | + | Addition | | | 7. | _ | Subtraction | | Some registers may not be used as a $\underline{\text{destination}}$ register. If they are used, a PASS instruction results. They are: - 1. Interrupt Register - 2. Instruction Bank Register - 3. Shift Count Register - 4. Miscellaneous Mode Register - 5. P Register - 6. Time Register (Clock) Add the contents of register A and Index Register 1 and transmit the result to A. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------|----------| | | R O P + A O B I O A | | | 1 2 3 4 5 6 7 8 | 9 10[11 [12]13]14 115 [16[17]16]19 [20[21]22[23[24]25[26[27]28[29]30[31]32[33]34 | | # PRQBLEM: Perform the "exclusive OR" between registers A and Q and transmit the result to D. # SOLUTION: | LOCN | | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | | $R \not O P_{a} \times O R_{a}$ | 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 | 10 [11 [12 [13 [14 [15 [16 [17 [16 [19 [20]21]22[23]24[25]26]27]28]29]30[31;32]33]34[35]36[3 | j<br>37 38 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: Subtract one from the D register and transmit the result to A. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------|--------------------------------------------------------------|------------------------------------------------------| | | $R O P_{1} - D_{1} P I_{2} A$ | | | 1 | 101111213141516117116117121312312412512612712812913013113213 | 313413513613713813914014:142143144145146147148149150 | #### PROBLEM: Perform the logical product between the contents of the A and Q registers and transmit the result to ${\bf D}_{\scriptscriptstyle{\bullet}}$ | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------| | | ROP. AND A. Q.D | 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 1 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 1 9 2 0 1 2 1 2 2 2 3 2 4 1 2 5 1 2 6 1 2 7 1 2 8 1 2 9 3 0 1 3 1 3 2 1 3 3 1 3 4 1 3 5 1 3 6 1 3 7 1 3 8 1 3 9 1 4 1 | 014/1421431441451451471481491501 | #### The REGISTER SWAP Instruction The REGISTER SWAP instruction is an instruction that performs an exchange of contents between two registers. No memory reference is made. IF CQ is specified and the q portion of the format is either AL, AU, QL, or QU, the complete register is cleared as the contents are being exchanged. If CR is specified and the r portion of the format is either AL, AU, QL, or QU, the complete register is cleared as the contents are being exchanged. Some registers may not be used in the swap. If they are used, they will not be changed. They are: - 1. Interrupt Register - 2. Instruction Bank Register - 3. Shift Count Register - 4. Miscellaneous Mode Register - 5. P Register - 6. Time Register (Clock) # The REGISTER TRANSMIT Instruction The REGISTER TRANSMIT instruction is an instruction that transmits the contents of one register (source) to another (destination). No memory reference is made. If CQ is specified, the contents of the register specified by the q portion of the format are cleared after the transmission takes place. If CR is specified <u>and</u> the r portion of the format is either AL, AU, QL, or QU, the complete register is cleared before the transmission takes place. If an attempt is made to alter the contents of the following registers, no action will take place. - 1. Interrupt Register - 2. Instruction Bank Register - 3. Shift Count Register - 4. Miscellaneous Mode Register - 5. P Register - 6. Time Register (Clock) Transmit Index Register 1 to Q. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------| | | $R \times T$ | 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 (13 114 115 ) 16 117 18 119 120 21 22 23 24 25 26 27 28 29 30 31 32 33 34 3 | 5 36 37 38 39 40 41 42 43 44 45 46 47 49 49 50 | # PROBLEM: Transmit A to D. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------------| | | RXT | | | 1 2 3 4 5 6 7 8 | 9 10 111 [12]13 [14]15 [16]17]18 119 [20]21]22]23]24 25]26 [27]28[29]30]31 [32]33]34]35]36]37 [36 | 139 40 4- 42 43 44 45 46 47 48 49 50- | # PROBLEM: Transmit Index Register 6 to A, then clear Index Register 6. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------|----------| | | $RXT_{i,j}CQ_{i,j}BG_{i,j}A_{i,j}$ | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 2 | 1 | # PROBLEM: Transmit A upper to A lower, then clear the rest of A except A lower. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------------------|----------------------------------------------------------------|--------------------------------------------------| | -1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1 | $R_{1}X_{1}T_{1}$ , $C_{1}R_{1}$ , $A_{1}U_{1}$ , $A_{1}L_{1}$ | ;<br>! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! | | 1 2 3 4 5 6 7 8 | 9 | <br> 36 37 38 39 40 4- 42 43 44.45 46 47 48 49 5 | | | · | | |--|---|--| | | | | | | | | #### NEW CONCEPTS OF GROUP 11 Programmers wishing top speed out of their programs would do well to consider the instructions in this group. They are the fastest, most versatile instructions in the repertoire. None of them require a memory reference. Any operational register can be used. This includes A, Q, D, and the index registers. There is a Compass mnemonic for each. These instructions can be used to maneuver data through the registers once the data has been read out of memory. Operations can be performed on the data with the ROP instruction. There are two types of operations: <u>Arithmetic</u> and <u>Logical</u>. Arithmetic operations include addition and subtraction. This is done using 1's complement mode in fixed point integer format. Logical operations are bit by bit comparisons. Here is a table showing how the bits in two given registers will yield results in the third register. Logical Operations | First Reg.<br>p | Second Reg.<br>q | p and q | INC.<br>p or q | EXC.<br>p or q | p IMP. q | p EQUIV q | |-----------------|------------------|---------|----------------|----------------|----------|-----------| | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | 0 | 1 | 0 | 1 | 1 | 1 | 0 | | 1 | 0 | 0 | 1 | 1 | 0 | 0 | | 1 | 1 | 1 | 1 | 0 | 1 | 1 | The last two instructions, RSW and RXT, perform no operation but can be used to interchange data or transmit data from one register to another. Let's show a couple of examples showing the effectiveness of these instructions. 1. Question: A programmer wishes to save the contents of A temporarily. What is the fastest way to do it? Answer: RXT A, D This is a transmission of A to D. 2. Question: A programmer wishes to complement the contents of A. What is the fastest way to do it? Answer: $R \phi P$ , $X \phi R$ A, MZ, A This is the "Exclusive $\ensuremath{\not} D \, R$ " with binary 1's. 11-16 ## Problem 11: Write a program that will count the number of times that the odd numbers between 1 and 100 are divisible by 5. Store the amount that you find at address ODDITY. Flowchart: Problem 11 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------| | 112121413161713 | 9 10 13 12 13 14 15 16 17 18 19 20 23 22 3 | 5 Çe 25 26 27 78 28 30 31 23 35 34 38 36 37 38 37 40 | 43 42 43 44 45 44 47 48 47 28 51 52 53 53 53 53 55 55 55 | | | IDENT DODI | lum | | | | ENTRY PODI | lum | <u> </u><br><u> </u> | | PDDITY | DEC O | <u> </u> | | | FIVE | DEC | <u> </u> | | | @DONUM. | BSS 1 | <u> </u> | | | | ENA 1 | <u> </u> | | | | RXT $A, D$ | | | | 14-1-1-1 | ENT 2.1 | | | | WEXT | RPP2+ D, B: | $\iota_{\mathcal{A}}$ | WEXT ODD | | اختصا | | 00 DDDNUM | | | | ENQ O | | | | | DVI FIVE | | | | | RJP, NZ NEXT | | | | | RAO ODDI | | | | | SLJ WEXT | | | | | END | | | ## Student Problem 11A: A sequence of terms looks like the following: $$S = 1, 3, 7, 13, 21, 31, 43, \dots$$ Of the first 100 terms, collect all terms divisible by 7 and store them in a table starting at address SET7. Flowchart: ## Problem 11A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 112121412141714 | • 10 10 10 10 10 10 10 1 | 1 77 27 36 36 37 36 37 36 37 38 31 32 33 34 35 36 37 38 37 38 | 01 02 03 04 05 04 05 04 05 05 15 15 15 15 15 15 | | | <del> </del> | | | | | 1 | <u> </u> | | | | <del> </del> | | | | | + | | | | 4 4 4 4 4 4 | | | karanda karanda garagan and aranda karanda da d | | | | <u>i i i i i i i i i i i i i i i i i i i </u> | <u> </u> | | | <del> </del> | | <u> </u> | | | +++++++++++++++++++++++++++++++++++++++ | | <u> </u> | | | + | ب المساولة | <u></u> | | | + | - A | A contract of the second secon | | | 1 | | <u> </u> | | | | <u> </u> | <u> </u> | | | | | | | | | | | | | | | | Swap the contents of Index Registers 2 and 3. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------| | | RSW | 1 1 4 1 1 1 4 4 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 37 38 39 40 41 42 43 44 45 45 47 48 49 50 | ## PROBLEM: Swap the contents of the A and D registers. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------|----------| | | $R_1S_1W_1$ | 1 | | 112131415151718 | 9 10 11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | | ## PROBLEM: Swap the contents of A lower and Index Register 1. #### SOLUTION: | LOCN | | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---|------------------------------------|----------------------------------------------------------------| | | | R.S.W. AL.B.1 | 1 | | 1 2 3 4 5 6 7 8 | , | , | 10 31 32 33 34 35 36 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Swap the contents of A lower and Index Register 2, clearing the rest of A. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------|----------| | 1.1.1.1.1.1 | RISW.CQ AL.B.2 | | | 1 2 3 4 5 6 7 8 | 9 10 11 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 13 | <br> | # GROUP 12 ## SHIFTING OPERATIONS #### GROUP 12 ## SHIFTING OPERATIONS | 1. | A Right Shift | ARS | |----|------------------|-----| | | A Left Shift | ALS | | 3. | Q Right Shift | QRS | | 4. | Q Left Shift | QLS | | | Long Right Shift | LRS | | 6. | Long Left Shift | LLS | | 7. | Scale A | SCA | | 8. | Scale AQ | SCQ | | | | | This group of instructions shifts the contents of A, Q, or AQ to the right or left in order to most effectively position data. No memory reference is required. The first six instructions are normal shifts that can be augmented as "end-off", or whose direction can be reversed under certain conditions. The last two instructions are used to scale quantities in the registers. The scaling of the quantity, along with the retaining of the scale factor, allows the programmer to solve highly complex problems of data manipulation with speed and accuracy. ## The A RIGHT SHIFT Instruction The A RIGHT SHIFT instruction is an instruction that shifts the contents of A, end-off, with sign extended (assuming there are no modifiers). The number of binary positions shifted is specified by $\underline{K}$ where $K = k + (B^b) + (V^v)$ . The maximum number of shifts for K is 48. If more than 48 are attempted, the shift is blocked and a Shift Fault occurs. If EO is specified by the programmer, the shift is end-off with zeros extended. If SS is specified by the programmer, the direction of the shift will change if K < 0. For example, an A RIGHT SHIFT where K < 0 will actually shift left, end-around. The number of positions shifted would be the absolute value of K. This is all checked and done in the hardware. Right shift the A register 15 places. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------|--------------------------------------------------------| | | A.R.S. 1.5 | | | 1 2 3 4 5 6 7 6 | 9 10[11 [12[13]14]15[16[17]18[19]20[21]22[23]24[25[26]27[28[29]30[31]32]33[34 | j<br> 35 36 37 38 39 40 4: 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Right shift the A register by the number of places specified in Index Register 1. #### SOLUTION: | LOCN | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|---|-----------------------------------------------------|-----------------------------|----------| | | | ARS | $\mathcal{I}_{1}$ | | | 1 2 3 4 5 6 7 8 | 9 | 10 11 12 13 14 15 16 17 18 19 2 | 0 2 22 23 24 25 26 27 28 2 | <br> | ## PROBLEM: Right shift the A register six places, end-off. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------|------------------------------------------------| | | A.R.S., E.Ø. 6 | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 16 117 18 119 20 21 22 22 32 4 22 5 26 27 28 29 30 31 32 23 33 34 32 | 5 36 37 38 39 40 41 42 43 44 45;46 47 48 49;50 | ### PROBLEM: Perform a right shift of six places if Index Register 5 contains 6. Perform a left shift of six places if Index Register 5 contains -6. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------| | | A.R.S. | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | 39,4014/142143144145/46147/48:49/50/ | #### The A LEFT SHIFT Instruction The A LEFT SHIFT instruction is an instruction that shifts the contents of A, end-around (assuming there are no modifiers). The number of binary positions shifted is specified by K where $K = k + (B^b) + (V^V)$ . The maximum number of shifts for K is 48. If more than 48 are attempted, the shift is blocked and a Shift Fault occurs. If EO is specified by the programmer, the shift is end-off with zeros extended. If SS is specified by the programmer, the direction of the shift will change if K < 0. For example, an A LEFT SHIFT where K < 0 will actually shift right, end-off. The number of positions shifted would be the absolute value of K. This is all checked and done in the hardware. Left shift the A register by 15 places. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------| | | ALS 15 | | | . 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 5 36 37 38 39 40 4: 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Left shift the A register by the number of places specified in Index Register 2. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------------------------------------------------|----------| | | ALS. | | | 1 2 3 4 5 6 7 8 | 9 10 [11 ]12 [13 ]14 [15 [16 ]17 [18 ]19 [20]21[22[23]24[25]26[27]28[29]30[31 [32]33 [34]35 | | ## PROBLEM: Left shift the A register six places, end-off. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | ALS, EØ | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11: 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 128 129 130 131 132 133 134 13 | 5/36/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/38/37/37/37/37/37/37/37/37/37/37/37/37/37/ | PROBLEM: Given: (B<sup>1</sup>) = a positive or negative number. If $(B_1^1) \ge 0$ , left shift A by the value in Index Register 1. If $(B^1) < 0$ , right shift A by the absolute value in Index Register 1. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------| | | $A_{1}L_{1}S_{1}S_{1}S_{1}$ | | | 1 2 3 4 5 6 7 8 | 9 10[11 [12]13]14]15]16[17]18]19]20[21]22[23]24]25[26]27[28]29[30[31]32[33]34]35]36 | <br> 37 38 39 40 4- 42 43 44 45 46 47 48 49 50 | ## The Q RIGHT SHIFT Instruction The Q RIGHT SHIFT instruction is an instruction that shifts the contents of Q, end-off, with sign extended (assuming there are no modifiers). The number of binary positions shifted is specified by $\underline{K}$ where $K = k + (B^b) + (V^v)$ . The maximum number of shifts for K is 48. If more than 48 are attempted, the shift is blocked and a Shift Fault occurs. If EO is specified by the programmer, the shift is end-off with zeros extended. If SS is specified by the programmer, the direction of the shift will change if K < 0. For example, a Q RIGHT SHIFT where K < 0 will actually shift left, end-around. The number of positions shifted would be the absolute value of K. This is all checked and done in the hardware. QRS E X A M P L E S PROBLEM: Right shift the Q register by 15 places. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------|-----------------------------------------------| | | Q.R.S. 15 | ; | | 1 2 3 4 5 6 7 8 | <br> | 36 37 38 39 40 4: 42 43 44 45 46 47 48 49 50: | ## PROBLEM: Right shift the Q register by the number of places specified in Index Register 6. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|-------------------------------------------------------------------------------------------------------------|----------| | | QRS | | | 1 2 3 4 5 6 7 8 | 9 .0 111 112 113 114 115 116 117 118 119 120 221 221 231 241 25 126 127 128 129 130 131 132 133 134 135 136 | | $\begin{array}{c} \text{PROBLEM:} \\ \text{Right shift the Q register by six places, end-off.} \end{array}$ ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |---------------------------|---------------------------------------------------------------------------------------|----------| | | QRS, Ed 6 | 1 | | 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 123 24 125 26 127 28 129 30 131 32 133 134 | | PROBLEM: Given: $(B^3) = -38$ during one pass of a loop. Left shift Q by the absolute value of this quantity. | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------| | | $Q_1R_1S_1$ , $S_1S_1$ | | | 1 2 3 4 5 6 7 8 | 9 (0 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 3 | 6137138139140141142143144145145147140140140 | ## The Q LEFT SHIFT Instruction The Q LEFT SHIFT instruction is an instruction that shifts the contents of Q, endaround (assuming there are no modifiers). The number of binary positions shifted is specified by $\underline{K}$ where $K = k + (B^b) + (V^v)$ . The maximum number of shifts for K is 48. If more than 48 are attempted, the shift is blocked and a Shift Fault occurs. If EO is specified by the programmer, the shift is end-off with zeros extended. If SS is specified by the programmer, the direction of the shift will change if K < 0. For example, a Q LEFT SHIFT where K < 0 will actually shift right, end-off. The number of positions shifted would be the absolute value of K. This is all checked and done in the hardware. PROBLEM: Left shift the Q register by 15 places. #### SOLUTION: | LOCN | | OPERATION, MODIFIERS ADDRES | S FIELD | COMMENTS | |-------------------------------|---|-----------------------------|-------------------|--------------| | | | QL5 15 | | 111111111111 | | 1 2 3 4 5 6 7 8 | 9 | <br> | 24 25 26 27 28 29 | <br> | #### PROBLEM: Left shift the Q register by the number of places specified in Index Registers 2 and 3. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------------------|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | QLS | | | 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10 11 12 13 14 15 [16]17 18 19 120 21 22 23 24 25 26 27 128 29 30 13 13 2 3 3 3 4 3 5 3 6 18 | 7 38 39 40 4+ 42 43 44 45 46 47 48 49 50 | ### PROBLEM: Left shift the Q register by six places, end-off. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------|-----------------------------------------------------------------------------------------------|-----------------------------------------| | | QLS, ED | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 12 13 14 15 16 17 18 | 9 10 111 1-2 13 14 115 116 117 118 119 20 21 22 23 24 25 126 27 128 22 130 131 132 133 134 35 | | ## PROBLEM: Shift the Q register according to the contents of Index Register 2. If $(B^2) \geq 0$ , left shift Q by the value in Index Register 2. If $(B^2) \leq 0$ , right shift Q by the absolute value in Index Register 2. | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------|------------------------------------------------| | | QLS, SS, , , , , , , , , , , , , , , , , | 1 | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12]13]14 [15]16 [17]18 [19]20[21]22[23]24[25]26[27]28[29]30[31 [32]33 [34]35[36[37 | ;<br>[38]39]40]4: [42]43]44;45]46]47]48 49[50] | ## The LONG RIGHT SHIFT Instruction The LONG RIGHT SHIFT instruction is an instruction that shifts the contents of AQ, end-off, with sign extended (assuming there are no modifiers). The number of binary positions shifted is specified by $\underline{K}$ where $K = k + (B^b) + (V^V)$ . The maximum number of shifts for K is 96. If more than 96 are attempted, the shift is blocked and a Shift Fault occurs. If EO is specified by the programmer, the shift is end-off with zeros extended. If SS is specified by the programmer, the direction of the shift will change if K < 0. For example, a LONG RIGHT SHIFT where K < 0 will actually shift left, end-around. The number of positions shifted would be the absolute value of K. This is all checked and done in the hardware. Right shift AQ by 38 places. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------| | | L,R,S, 1, 1, 1, 1, 3,8, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, | j | | , [2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | 10 4- 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Right shift AQ by the number of places specified in Index Register 4. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------|------------------------------------------| | | LRS | | | 1 1 2 3 4 5 6 7 8 | 9 10 [11 [12]13 [14]15 [16]17 [18]19 [20]21 [22]23 [24]25 [26]27 [28]29 [30]31 [32]33 [34]35 [36]37 | 3813914014. 1421431441451451471401491501 | #### PROBLEM: Right shift AQ by 24 places, end-off. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------| | | $L_{RS}, E_{\phi}$ | 1 | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10[11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23] [24] [25] [26] [27] [28] [29] [30] [31] [32] [33] [34] [35] [36] [37] [38] | 13914014.142143144145146147148149150 | ### PROBLEM: Shift AQ according to the contents of Index Registers 3 and 4. If $(B^3) + (B^4) \ge 0$ , right shift AQ by the sum of their values. If $(B^3) + (B^4) < 0$ , left shift AQ by the absolute value of the sum of their values. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------|----------------------------------------------------------------------------------|----------------------------------------------| | | LRS, SS | | | 1 | 9 10[11][12]13]14]15[16[17]18]19[20[21]22[23[24]25[26[27]28[29]30[31]32[33[34]35 | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### The LONG LEFT SHIFT Instruction The LONG LEFT SHIFT instruction is an instruction that shifts the contents of AQ, end-around (assuming there are no modifiers). The number of binary positions shifted is specified by $\underline{K}$ where $K = k + (B^b) + (V^v)$ . The maximum number of shifts for K is 96. If more than 96 are attempted, the shift is blocked and a Shift Fault occurs. If EO is specified by the programmer, the shift is end-off with zeros extended. If SS is specified by the programmer, the direction of the shift will change if K < 0. For example, a LONG LEFT SHIFT where K < 0 will actually shift right, end-off. The number of positions shifted would be the absolute value of K. This is all checked and done in the hardware. LLS EXAMPLES PROBLEM: Left shift AQ by 38 places. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |---------------------------------|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------| | | LLS 38 | 1.1.1.1.1.1.1.1.1.1.1 | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 1 | 9 G; - 213 415 :6 17 :8 :9 20 21 :22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 3 | 914014: 1421431441451461471481491502 | #### PROBLEM: Left shift AQ by the value specified in Index Register 1. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------| | | LLS, | 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | 40[41 42 43 44 45 46 47 48 49 50 | ### PROBLEM: Left shift AQ 93 places, end-off. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------| | | LLS, EØ , 93 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | 35 36 37 38 39 40 4: 42 43 44 45 46 47 48 49 50: | ## PROBLEM: Shift AQ according to the contents of Index Register 5. If $(B^5) \ge 0$ , left shift AQ by the value in Index Register 5. If $(B^5) < 0$ , right shift AQ by the absolute value in Index Register 5. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |----------------------------|----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------| | | LLS, SS, 1, 5 | | | 12 3 4 5 6 7 8 | 9 10 1-1 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### The SCALE A Instruction The SCALE A instruction is an instruction that scales an operand in the A register. The scale factor, K minus the number of left shifts needed to scale, replaces the contents of the designated index register specified by b. If the contents of A are originally zero, scaling is not performed and K replaces the contents of the index register. If the operand is already scaled, K replaces the contents of the index register. If K is less than the number of left shifts needed to scale, only K number of left shifts will result. The operand will not be scaled and zeros will replace the contents of the index register. The bank term $\underline{a}$ determines the value of the operand bank setting. If it is not used, the current operand setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. Scale A using 2057 octal for K. Scale factor goes to Index Register 1. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|----------| | | S.C.A. 2057B, 2 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | | #### PROBLEM: Scale A using 3 for K. Scale factor goes to Index Register 2. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|-------------------------------------------------------------------------------------------------|-----------------------------------------| | | S.C.A. 3.2 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 [2 3 4 5 6 7 8 | 9 (0]11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | | ## PROBLEM: Scale A using the contents of Index Register 4 for K. Scale factor goes to Index Register 5. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|---------------------------------------------------------------------------------------------------------|------------------------------------------| | | SCA 19594 | 1 | | 1 [2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 220 23 124 125 126 127 128 129 130 131 132 133 134 135 136 137 | 138139140141142143144145146147149149150. | #### PROBLEM: Scale A using k = 15 modified by Index Register 3 for K. Scale factor goes to Index Register 4. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | | S.C.A. 1.5, 4, 3 | | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 14 / 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 14 / 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 14 / 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 14 / 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 14 / 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 14 / 15 20 21 21 21 21 21 21 21 | l l | ## The SCALE AQ Instruction The SCALE AQ instruction is an instruction that scales an operand in the AQ registers. The scale factor, K minus the number of left shifts needed to scale, replaces the contents of the designated index register specified by $\underline{b}$ . If the contents of AQ are originally zero, scaling is not performed and K replaces the contents of the index register. If the operand is already scaled, K replaces the contents of the index register. If K is less than the number of left shifts needed to scale, only K number of left shifts will result. The operand will not be scaled and zeros will replace the contents of the index register. The bank term $\underline{a}$ determines the value of the operand bank setting. If it is not used, the current operand setting will be replaced by the value $\underline{a}$ . In either case it will not affect this instruction. However, it could affect future instructions that reference memory for operands. Scale AQ using 2057 octal for K. Scale factor goes to Index Register 1. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------|----------| | | SCQ 2057B, 1 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 21 22 23 24 25 26 27 28 29 30 31 | <br> | #### PROBLEM: Scale AQ using the contents of Index Register 3 for K. Scale factor goes to Index Register 4. ## SOLUTION: | LOCN | | OPERATION, MODIFIERS A | DDRESS FIELD | COMMENTS | |-------------------------------|---|------------------------------------------------------|----------------------------------------------------|--------------------------------------------------------------------| | | | SCQ | 4,,3, , , , , , , , , , , , , , , , , , | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 | 10 11 12 13 14 15 16 17 18 19 20 | ?! 22 23 24 25 26 27 28 29 30 3! 32 33 34 35 36 3; | 7 38 39 40 41 42 43 44 45 46 47 48 49 50 | ### PROBLEM: Scale AQ using 6 for K. Scale factor goes to Index Register 2. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------|-------------------------------------| | | 500 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 13 14 15 16 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 13 | 9140141142143144145146147148149150. | #### PROBLEM: Scale AQ using 9 modified by Index Register 5 for K. Scale factor goes to Index Register 1. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------| | | SCQ 9125 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 13 | 16[37[38]39]40[4:[42]43[44]45[46[47]48[49]50 | #### NEW CONCEPTS OF GROUP 12 For any register, whether it be A, Q, or AQ, it should be remembered that the normal shifts to the right are end-off with sign extended, and that the normal shifts to the left are end-around. Operation field modifiers can change the pattern of shifting. The modifier <u>EO</u> means <u>end-off</u>. This means that no matter which direction the shift, it is always end-off, and zeros are always extended. It's like a table holding a line of rubber balls. As you push the balls in either direction, they fall off and none replace them. The modifier <u>SS</u> will change the direction of the shift if K< 0. Usually K varies during the program from positive to negative and vice versa allowing the programmer to position and reposition data. The scale instructions allow the programmer to convert numbers to different computer formats. Here the left shift takes place until the most significant bit is just to the right of the sign bit. This is so that the sign of the operand does not change and so that it is in fractional format. For each left shift the contents of an index register is reduced by 1. This quantity is called the scale factor. For each left shift of 1 the operand is effectively multiplied by 2. Correspondingly the exponent is reduced by 1. This means that the operand with the exponent always retains the same value. In other words an octal $5 \cdot 2^6$ is equal to an octal $50 \cdot 2^3$ (note the multiplying of the coefficient and the reducing of the exponent). ## Problem 12: Assume a set of BCD characters has been read into memory starting at address INPUTREG, but that the characters are backwards. Write a subprogram that will reverse the assembly of the first word. In other words: (INPUTREG) = HGFEDCBA should be (INPUTREG) = ABCDEFGH Problem 12 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------|----------------------------------------------|-------------------| | 1 2 2 4 3 4 7 4 | 5 10 11 17 17 14 15 16 17 18 19 | <br> | <br> | | | IDENT | REVERSE | <u> </u><br> | | | ENTRY | REVERSE | <u> </u> | | REVERSE | B.S.S | [2 | | | | | 0,1,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | CHARACTER COUNTER | | | KDA | INPUTREG | | | | LRS, E.Ø | 48 | | | | | 42:::::: | | | | | <b>6.</b> | | | WEXTCHAR | i i . | 36 | | | | 445 | 6 | | | | | 16,1 | 8-2 LEFT | | | | NEXTCHAR | <u> </u> | | | | INPUTREG | <u> </u> | | | | REVERSE | | | | END | <u> </u> | <u> </u> | Somewhere within this subprogram would also be included the symbol INPUTREG in the location field with a declaration of the prestored data or area reserved. The forming of the reverse assembly can be seen more clearly by the following figure: Instruction: LDA INPUTREG LRS, E $\phi$ 48 (A) = $$0$$ (Q) = H G F E D C B A Instruction: QLS 42 LLS 6 (A) = $$0 \longrightarrow 0$$ A (Q) = H G F E D C B 00 Instruction: QLS 36 LLS 6 (A) = $$0 \longrightarrow 0$$ A B (Q) = $00$ H G F E D C $00$ ## Student Problem 12A: A group of BCD characters at address REVASS looks like the following: Rearrange this word so that the letters are in alphabetical order. Flowchart: # Problem 12A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------| | 1 1 2 1 2 1 4 1 5 1 4 . 7 1 4 | <br> | 1 27 24 25 26 27 28 39 36 31 27 35 34 27 36 37 38 37 | 0.03.01010101010, 41.0 8.011010 N.O. 8.01010 (0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0 | | | | | <u> </u> | | | <u> </u> | <u> </u> | <u> </u> | | | <u> </u> | الماد في الماد الم | | | | <del></del> | <u> </u> | <u> </u> | | | | أرطد فريع متفريق لقط فكالمصطلح فللمصادر بهبيكي فريط سف | | | | | <u> </u> | | | | <del> _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ </del> | <u> </u> | | | المساما بنيا | | | <u> </u> | | | | | <u> </u> | | | | | | | | <u> </u> | A A A A A A A A A A A A A A A A A A A | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | <u> </u> | ## GROUP 13 ## LOGICAL OPERATIONS #### GROUP 13 #### LOGICAL OPERATIONS | 1. | Selective Set | SST | |----|----------------------|-----| | 2. | Selective Clear | SCL | | 3. | Selective Complement | SCM | | 4. | Selective Substitute | SSU | | 5. | Load Logical | LDL | | | Add Logical | ADL | | 7. | Subtract Logical | SBL | | 8. | Store Logical | STL | This group of instructions is used to manipulate binary data, and to set, clear, extract, and insert bits of data. One memory reference is required. The first three instructions will change bits in A depending on a mask in memory. The fourth instruction will substitute the bits of a memory word for A depending on the mask in Q. The last four instructions perform a logical product using the contents of Q as a mask. #### The SELECTIVE SET Instruction The SELECTIVE SET instruction is an instruction that checks each bit from an 18-bit storage address. One memory reference is made. The operation leaves the contents of the storage address unchanged. For every bit in the storage address that is in the set state (binary 1), the corresponding bit in the A register will be set, regardless of its initial state. Where there is a zero bit in the storage address, the corresponding bit in A will remain unchanged. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is read from memory and then each bit is checked as mentioned above. Perform a Selective Set with the contents of A and the storage address MSK. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------|----------| | | S.S.T. M.S.K | | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12 [13 [14 [15 [16 [17 [18 [19 [20]21]22]23]24]25]26 [27]28 [29]30[31 [32]33]34 | | #### PROBLEM: Perform a Selective Set using the contents of A and the storage address TOT modified by Index Registers 2 and 3. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------| | | S.S.T. TOT , 2, 3 | 1 | | 1 2 3 4 5 6 7 6 | 9 (0]11 [12]13 [14]15 [16]17 [18 [19]20[21]22[23]24[25]26[27]28[29]30[31]32[33]34]35[36[37 | 138 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Perform a Selective Set using the contents of A and the storage address specified in Index Register 6. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | SST | | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12 [13 ]14 [15 [16 [17 ]16 [19 ]20]21 [22]23]24]25 [26 [27]28 [29]30 [31 ]32[33 [34]35 [36] | 37 [38 39 40 41 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Perform a Selective Set using the contents of A and the storage address DICK from the bank where DICK resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------|---------------------------------------------------| | | SST / SI) DICK | 1 | | 1 2 3 4 5 6 7 8 | 9 10[11]12[13]14]15[16]17[18]19[20[21]22[23]24[25]26[27[28]29[30]31]32[35]31 | 4 35 36 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | #### The SELECTIVE CLEAR Instruction The SELECTIVE CLEAR instruction is an instruction that checks each bit from an 18-bit storage address. One memory reference is made. The operation leaves the contents of the storage address unchanged. For every bit in the storage address that is in the set state (binary 1), the corresponding bit in the A register will be cleared, regardless of its initial state. Where there is a zero bit in the storage address, the corresponding bit in A will remain unchanged. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is read from memory and then each bit is checked as mentioned above. Perform a Selective Clear using the contents of A and the storage address MSK1. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|----------------------------------------| | | $S_1C_1L_1$ | | | 1 2 3 4 5 6 7 8 | <br> | 38 39 46 4- 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Perform a Selective Clear using the contents of A and the storage address FIX modified by Index Registers 3 and 4. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------|------------------------------------|----------| | | S.C.L. F.I.X., 3,2,4 | | | 1 2 3 3 4 5 6 7 6 | <br> | <br> | #### PROBLEM: Perform a Selective Clear using the contents of A and the storage address specified in Index Register 5. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|-------------------------------------------------| | | S.C.L | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | <br> | 513613713813914014.142143)44145146147148149150. | #### PROBLEM: Perform a Selective Clear using the contents of A and the storage address SCRIPT in the bank where the SCL resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|-----------------------------------------------------------------------------------|----------------------------------------------| | | S.C.L. (*)S.C.R.I.P.T | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 3 | 61371381391401411421431441451451471481491501 | ## The SELECTIVE COMPLEMENT Instruction The SELECTIVE COMPLEMENT instruction is an instruction that checks each bit from an 18-bit storage address. One memory reference is made. The operation leaves the contents of the storage address unchanged. For every bit in the storage address that is in the set state (binary 1), the corresponding bit in the A register will be complemented, regardless of its initial state. Where there is a zero bit in the storage address, the corresponding bit in A will remain unchanged. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = m + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is read from memory and then each bit is checked as mentioned above. Perform a Selective Complement using the contents of A and the storage address MAX. #### SOLUTION: | LOCN | | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---|------------------------------------|--------------------------------------| | | | $S_{\mathcal{C},M}$ | | | 1 2 3 4 5 6 7 8 | 9 | <br> | 39 40 4: 42 43 44 45 46 47 48 49 50; | #### PROBLEM: Perform a Selective Complement using the contents of A and the storage address SUP modified by Index Registers 1 and 2. #### SOLUTION: | LOCN | | OPERATION, MODIFIERS AD | DRESS FIELD | COMMENTS | |-------------------------------|---|-------------------------|-------------|----------------------------------------------------------------------------------------------| | | | S.C.M | P 2 1 2 | | | 1 2 3 4 5 6 7 8 | 9 | l | , , | 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Perform a Selective Complement using the contents of A and the storage address specified in Index Register 3. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------|----------------------------------------------------------------------------------------|------------------------------------------| | | S <sub>1</sub> C <sub>M</sub> | | | 1 | 9 10]11 [12]13]14]15[16]17]18[19]20[21]22[23]24]25.26[27]28[29]30]31]32[33]34[35]36[37 | 138139140141142143144145146147148149150. | ## PROBLEM: Perform a Selective Complement using the contents of A and the storage address SWITCH in the bank of SWITCH. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------| | | S.C.M. (#)S.W.I.T.C.H | | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 10 [11 [12] 13 [14 [15 [16] 17 [18 [19] 20] 21 [22] 23] 24 [25] 26 [27] 28 [29] 30[ 31 [32] 53 [34] 3 | 35 36 37 38 39 40 41 42 43 44 45 46 47 48149,57: | #### The SELECTIVE SUBSTITUTE Instruction The SELECTIVE SUBSTITUTE instruction is an instruction that checks each bit from an 18-bit storage address. One memory reference is made. The operation leaves the contents of the storage address unchanged. For every bit in the Q register that is in the set state (binary 1), the corresponding bit from the storage address will be transferred to the A register. Where there is a zero bit in the Q register, the corresponding bit from the storage address will not be transferred to A. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is read from memory and then each bit is checked as mentioned above. PROBLEM: Given: (Q) = 77777 octal Perform the Selective Substitute with the contents of A and storage address HENCH. #### SOLUTION: | LOCN | | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---|------------------------------------|-------------------------------------| | | | S.S.U. H.E.N.C.H. | | | 1 [ 2 3 4 5 6 7 8 | 9 | <br> -0 | 3914014 142243244145145147240249140 | PROBLEM: Given: (Q) = 770——0 octal Perform the Selective Substitute with the contents of A and storage address BOX modified by Index Registers 2 and 3. #### SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------|----------| | | S.S.U. B.Ø.X., 2, 3 | 1 | | 1 2 3 4 5 6 7 8 | | | PROBLEM: Given: (Q) = 7 octal Perform the Selective Substitute with the contents of A and the storage address specified in Index Register 3. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |--------------------------|------------------------------------------------------------------------------------------------------|-------------| | | S.S.U. | | | 1 12 13 14 15 16 17 18 1 | 9 10 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 | 16.16.17.19 | PROBLEM: Given: (Q) = 77 octal Perform the Selective Substitute with the contents of A and the storage address HOMER from the bank where HOMER resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------|----------------------------------------------------------------------------------------|---------------------------------------------------------------------| | | SISU (\$)HØMER | | | 1 | 9 10[11 [12]13]14 [15]16[17]18]19 [20[21]22[23]24[25]26[27]28[29]30[31 [32]33[34]35[36 | 137 [38 39 40 41 42 43 44 45 46 47 48 49 50 | #### The LOAD LOGICAL Instruction The LOAD LOGICAL instruction is an instruction that forms the logical product between the contents of an 18-bit storage address and the contents of the Q register with the result replacing the contents of A. One memory reference is made. The operation leaves the contents of the storage address unchanged. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. PROBLEM: Given: (Q) = 77 octal Load the lowest six bits from address JACK into the A register. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------|------------------------------------|-----------------------------------------| | | LDL | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | ı | PROBLEM: Given: (Q) = 770—0 octal Load the highest six bits from address CHAR modified by Index Register 3 into the A register. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------|---------------------------------------------| | | L.D.L. C.H.A.R., 3 | | | 1 2 3 4 5 6 7 8 | | 6 37 38 39 40 4+ 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: (Q) = 77777 octal Load the lowest 15 bits from the address specified in Index Register 6 into the A register. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------| | | L.D.L. 1916 | !<br>1_1_1_1_1_1_1_1_1_1_1_1_1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 10 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 136 37 138 39 40 41 42 43 44 45 46 47 48 49 50 2 | PROBLEM: Given: (Q) = 777770—0 octal Load the highest 15 bits from address KARAC from the bank where KARAC resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------------|------------------------------------|----------| | 11111 | L.D.L. (\$)KARAC | | | 1 2 3 4 3 5 6 1 7 1 8 | | <br> | #### The ADD LOGICAL Instruction The ADD LOGICAL instruction is an instruction that forms the logical product between the contents of an 18-bit storage address and the contents of the Q register and adds this result to the contents of A. One memory reference is made. The operation leaves the contents of the storage address unchanged. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = m + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. PROBLEM: Given: (Q) = 77 octal Add the lowest 6-bit character from address TAB to the A register. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|--------------------------------------------| | | ADL | | | 1 2 3 4 5 6 7 8 | <br> | 3713813914014 1421431441451461471481491502 | PROBLEM: Given: (Q) = 770 - 0 octal Add the highest 6-bit character from address SAM modified by Index Register 2 to the A register. #### SOLUTION: | LOCN | PERATION, MODIFIERS ADDRESS | FIELD COMMENTS | |------------------------|----------------------------------------------|----------------| | | DL SAM, 2 | | | 1 12 13 14 15 16 17 18 | [11 [12]13]14]15[16]17]18]19[20[21]22[23]24] | <br> | PROBLEM: Given: (Q) = 77777 octal Add the lowest 15 bits from the address specified in Index Register 4 to the A register. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|--------------------------------------------------------------------| | | A.D.L. | | | 1 2 3 4 5 6 7 8 | 9 | 7 38 39 40 41 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: (Q) = $777770 \longrightarrow 0$ octal Add the highest 15 bits from address BULDGE from the bank where the ADL resides. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------| | | A.D.L. (*) B.U.L.D.G.E | | | 1 | 9 .01 1 1 2 1 3 1 4 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 3 1 3 2 3 3 3 4 3 5 | 36 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | #### The SUBTRACT LOGICAL Instruction The SUBTRACT LOGICAL instruction is an instruction that forms the logical product between the contents of an 18-bit storage address and the contents of the Q register and subtracts this result from the contents of A. One memory reference is made. The operation leaves the contents of the storage address unchanged. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. PROBLEM: Given: (Q) = 77 octal Subtract the lowest 6 bits at address BAKER from the A register. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------| | | SBL | | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 3 | j<br>34 35 36 37 38 39 40 4+ 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: (Q) = 77777 octal Subtract the lowest 15 bits at address ABLE modified by Index Register 5 from the A register. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------|----------| | 1 1 1 1 1 1 1 | SBL ABLE 5 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | <br> | PROBLEM: Given: (Q) = 000777770-0 octal Subtract the indicated 15 bits at the address specified in Index Register 1 from the A register. # SOLUTION: | LOCN | | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|---|------------------------------------|------------| | | | S.B.L. | 1111111111 | | : 2 3 4 5 6 7 8 | 9 | | | PROBLEM: Given: (Q) = 0—077700000 octal Subtract the indicated nine bits at address DOG in the bank where DOG resides from the A register. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | | S.B.L. (#) D.Ø.G | | | 1 2 3 4 5 6 7 6 | 9 10 11 12 13 14 15 16 17 8 19 20 21 22 23 24 25 26 27 26 29 30 31 32 33 34 35 36 37 38 | 1<br>39[40]4-]42[43]44[45]46[47]48-49[53 | #### The STORE LOGICAL Instruction The STORE LOGICAL instruction is an instruction that forms the logical product between the contents of the A register and the contents of the Q register with the result replacing the contents of an 18-bit storage address. One memory reference is made. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. PROBLEM: Given: (Q) = 77 octal Store the lowest 6 bits of the A register at address TOM. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------|----------| | | STL | | | 1 2 3 4 5 6 7 8 | 10 [11 [12 [13 [14 ]15 [16 [17 [18 ]19 [20 [21 [22 [23 [24 [25 [26 [27 [28 [29 [30 [31 [32 [33 ]34] | | PROBLEM: Given: (Q) = 770—0 octal Store the highest 6 bits of A at address PETE modified by Index Register 2 and 3. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------| | | S.T.L. PETE, 2, 3 | L 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 3 | 35 36 37 38 39 40 4:142 43 44 45 46;47,48:49 5\ | PROBLEM: Given: (Q) = 77777 octal Store the lowest 15 bits of A at the address specified in Index Register 4. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|----------| | | STL | | | 1 2 3 4 5 6 7 8 | <br> | <br> | PROBLEM: Given: (Q) = 77 octal Store the lowest 15 bits of A at address JOE in the bank where the STL resides. | LOCN | | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|---|------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | | STL (*) JOE | | | 1 12 3 4 5 6 7 8 | 9 | 10 ( 112 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 29 | 12913013113213313413513613713813914014.142143344145146147148149150 | | | | · | | |--|--|---|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # NEW CONCEPTS OF GROUP 13 This group involves many logical operations, i. e. bit by bit comparisons. Bits are grouped in order to mask (extract) certain portions of words. Under "logical product" the multiplication of any bit by "1" returns that bit, whereas the multiplication of any bit by "0" returns zero. Using this principle the programmer can extract and analyze any part of a word. # Problem 13: A set of 64 BCD characters representing numbers from 0 through 9 are in memory starting at address TRIAL. If each CXX represents one 6-bit character, they are set up as follows: | (TRIAL) = | 565 | C02 | C03 | C04 | C05 | C06 | C07 | Cq8 | |-------------|-----|-----|-----|------|----------|------|------|------------| | | C09 | CHO | C11 | C12 | C13 | C14 | C15 | C 16 | | | C17 | C18 | C48 | C20 | C21 | C22 | C23 | C24 | | | C25 | C26 | C27 | C28_ | C29 | C30 | C31 | C32 | | | C33 | C34 | C35 | C36 | <u> </u> | C38 | C39 | C40 | | | C41 | C42 | C43 | C44 | C45 | C46_ | C47· | C48 | | | C49 | C50 | C51 | C52 | C53 | C54 | C55_ | C56 | | (TRIAL+7) = | C57 | C58 | C59 | C60 | C61 | C62 | C63 | C44 | | | | | | | | | | ₩ <i>→</i> | Write a subprogram that will form the sum of the characters represented by the diagonal line and the sum of the characters represented by the vertical line. Compare the two sums and store the smaller sum at address MINIMIZE. # Flowchart: Problem 13 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIE | ERS ADDRESS FIELD | COMMENTS | |-------------------------------------|--------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 2 2 4 4 4 6 7 4 | • | <br> | 1.20 MA 41 42 43 44 45 44 47 44 47 36 31 32 33 34 25 36 37 38 37 38 41 42 43 43 45 46 47 48 47 48 47 48 47 48 48 | | | IDENT | MINFUN | | | | ENTRY<br>BSS | MINFUN | | | MINIMIZE | BSS | 11 | | | MINFUN | BSS | 12. | | | | ENI | 0,1 | | | | ENA | 0 | | | | RXT | A,D | | | | ENQ | 17.8 | MASK IN Q | | | QLS | 142 | | | WEXT | 554 | TRAIL,1 | | | | QRS. | 6 | | | | ISK | 17.2 | & CHAR? | | | 54.5 | WEXT | | | | LRS, E.D. | 148 | | | VEXT1 | 445 | <u>16</u> | | | | RAPIT | A, D, O | D+NEXT CHAR | | | ENA | <i>b</i> | | | 4 4 1 1 1 1 1 1 | Isk | 7,2 | 8 CHAR? | | | SLJ | WEXT1 | | | | ENQ | 11.7.8 | | | WEXTA | A.D.L<br>F.S.K | TRIAL, 1 | | | | ISK | 17.3.2 | 8 CHAR? | | <u> </u> | 545 | WEXTA | | | <u> </u> | RPP2- | A, D, Q<br>DIAGSM | <br> | | | OJP, PL | DIAGSM | | | | 57A | MINIMIZE | A.4T.D | | | SLJ | MINFUN | | | DIAGSM. | RXT | D-A | | | | s.T.A. | D.A.<br>MINIMIZE | D. LT. A | | | 54J | MINFUN | | | <u> </u> | END | ;<br> | | | ı | 1 | | | Somewhere within this subprogram would also be included the symbol TRIAL in the location field with a declaration of the prestored data or area reserved. It is left to the reader as a challenge to determine the contents of A and Q after each instruction, as was done in the previous problem. # Student Problem 13A: Using problem 13, determine the minimum value between the sum of the 5th column and the opposite diagonal. # Flowchart: # Problem 13A could be solved by coding in the following manner: | 1000=100 | OREN ATION MODIFIERS | ADDRESS FIELD | COMMENTS | |------------------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LOCATION | OPERATION, MODIFIERS | VANKE22 LIEFA | COMMENTS | | 1 12 12 14 14 14 17 14 | * (m; 11 12 13 14 15 16 17 16 19 20 2 | 21 172 25 26 25 36 27 26 29 36 31 32 35 34 35 35 37 38 27 44 | 41 47 47 46 45 46 47 48 47 30 51 32 33 34 55 34 37 58 35 36 41 42 54 45 46 47 48 47 48 47 48 47 48 47 48 47 48 47 48 47 48 47 48 47 48 47 48 48 | | | | | | | | | | | | 1 1 1 1 1 1 1 | <u> </u> | | | | | | | <u> </u> | | | | <u> </u> | | | | | | <u> </u> | | | | | | | | | | <u> </u> | | | | | 1<br>1 | | | | | | | | <u> </u> | | <u> </u> | | | | <u> </u> | | | | <u> </u> | | | | | <del> </del> | | | | | <del> </del> | | <u> </u> | | | | | | | | <del> </del> | | <u> </u> | | 111111 | | | <u> </u> | | 111111 | | | <u> </u> | | | <del> </del> | | <u> </u> | | | <del> </del> | | <u> </u> | | | <del> </del> | | 1 | | | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | <u> </u> | | | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | <del></del> | <del> </del> | | <u> </u> | | | <del> </del> | | <u> </u> | | 1111111 | <del> </del> | | <u> </u> | | | | | 111111111111111111111111111111111111111 | | | +++++++++++++++++++++++++++++++++++++++ | | <u> </u> | | | <del> </del> | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | Liville | | | <u> </u> | # GROUP 14 # SINGLE PRECISION FLOATING POINT ARITHMETIC # GROUP 14 # SINGLE PRECISION FLOATING POINT ARITHMETIC | 1. | Floating Add | FAD | |----|-------------------|-----| | 2. | Floating Subtract | FSB | | 3. | Floating Multiply | FMU | | 4. | Floating Divide | FDV | This group of instructions performs floating point operations on the contents of A. One memory reference is required. Both operands must be in floating point format. The computer will automatically normalize and round the final coefficient resulting from the operation unless UN or UR is specified. The operation always leaves the answer in A with the residue in Q. #### The FLOATING ADD Instruction The FLOATING ADD instruction is an instruction that adds a 48-bit operand from an 18-bit storage address to the contents of A in floating point format. One memory reference is made. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = m + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is added to A. If MG is specified by the programmer, the magnitude (absolute value) of the operand is added to A. If RP is specified by the programmer, the result of the operation replaces the contents of the storage address besides the A register. In this case two memory references are made. Normally the coefficient will be normalized. If UN is specified by the programmer, the coefficient will be unnormalized. Normally the coefficient is rounded if one-half or greater. If UR is specified by the programmer, rounding will not take place. The initial contents of the Q register are always destroyed by this instruction. # PROBLEM: Add a floating point number from address NUM to the A register. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------|---------------------------------------------------| | _1,1,1,1,1,1,1 | FAD | | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12 [13 [14 [15 [16 [17]18 [19 [20 [21 [22 [23 [24 [25 [26 [27 [28 [29 [30 [31 [32 [33 [34 | 135136137138139140141142143144145145147140.49.40. | # PROBLEM: Add the absolute value of a floating point number from address BILL to the A register. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------| | | FAD | | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10 111 112 113 114 115 116 117 118 119 20 22 122 223 24 25 26 27 128 229 30 131 32 23 134 35 | 36137138139140141142143144145146147149149153 | # PROBLEM: Do a replace floating add from address BOB modified by Index Register 3. $\,$ #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------| | | FADIORIP BOBIOS | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | <br> 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Do a floating add from address TOJO using un-normalized arithmetic. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------| | | FAD, UN TOJO | | | 1 2 3 4 5 6 7 8 | 9 10[11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 36 37 38 39 40 4 142 43 44 45 46 47 48 49 50 | #### The FLOATING SUBTRACT Instruction The FLOATING SUBTRACT instruction is an instruction that subtracts a 48-bit operand at an 18-bit storage address from the contents of A in floating point format. One memory reference is made. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is subtracted from A. If MG is specified by the programmer, the magnitude (absolute value) of the operand is subtracted from A. If RP is specified by the programmer, the result of the operation replaces the contents of the storage address besides the A register. In this case two memory references are made. Normally the coefficient will be normalized. If UN is specified by the programmer, the coefficient will be unnormalized. Normally the coefficient is rounded if one-half or greater. If UR is specified by the programmer, rounding will not take place. The initial contents of the Q register are always destroyed by this instruction. #### PROBLEM: Subtract a floating point number at address JAKE from the A register # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|-------------------------------------------------------------------| | | F.S.B. JAKE | | | 1 2 3 4 5 6 7 8 | <br> | 413513613713813914014.1421414414514514514514514514514514514514514 | #### PROBLEM: Do a Floating Subtract using the address specified in Index Register 2. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------------------|--------------------------------------------| | | F.S.B. | | | 1 2 3 4 5 6 7 8 | 9 10 11 112 113 114 115 116 117 118 119 220 21 122 223 224 225 226 227 28 229 230 31 132 233 234 235 356 | 37[38]39]40]4.[42]43]44]45;46]47[48-49]5.; | #### PROBLEM: Subtract the absolute value of the floating point number at address PILL from the A register. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | | FSB, MG | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 3 | 713813914014 142141 44 45146141 49 45 60 | #### PROBLEM: Do a Floating Subtract using address BOX with unrounded arithmetic. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | OMMENIS | |--------------|---------------------------------------------------------------------------------------------------------------------------------|-------------------------| | | $F.S.B., U.R.$ $B.\phi \times$ | | | 1:13:4:5:6:7 | 8 19 10 112 1.4 1.4 1.5 1.6 1.7 1.8 1.9 1.5 1.5 1.7 2.7 23 1.5 4.125 1.6 1.2 7.8 1.7 20 2.7 2.7 2.7 2.7 2.7 2.7 2.7 2.7 2.7 2.7 | 21, 1 of #80-0,48 49,52 | # The FLOATING MULTIPLY Instruction The FLOATING MULTIPLY instruction is an instruction that multiplies a 48-bit operand from an 18-bit storage address by the contents of A in floating point format. One memory reference is made. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the complement of the operand is multiplied by A. If MG is specified by the programmer, the magnitude (absolute value) of the operand is multiplied by A. Normally the coefficient will be normalized. If UN is specified by the programmer, the coefficient will be unnormalized. Normally the coefficient is rounded if one-half or greater. If UR is specified by the programmer, rounding will not take place. The initial contents of the Q register are always destroyed by this instruction. # PROBLEM: Multiply the contents of A by the number at address SLINK. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------| | | F.M.U. SLINK | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 137/38/39/40/41/42/43/44/45/46/47/40:40/50/ | #### PROBLEM: Do a Floating Multiply using the address specified in Index Register 4. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------------------------------|----------------------------------| | | F.MU | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 13 14 15 16 17 18 19 120 21 122 123 124 125 126 127 128 129 130 31 132 33 134 135 136 137 138 139 1 | 40 4 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Do a Floating Multiply using address ${\tt BIGGEST}$ with un-normalized arithmetic specified. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | FMU.UN BIGGEST | | | 1 2 3 4 5 6 7 8 | 9 (0[1: [12]:3]:4[15]:6[17]:8[19]20[2: 22]23[24]25[26[27]28[29]30[3:[32]33[34]35[36[27] | 37 (38 39 40 41 42 43 44 45 46 47 48 49 50 | # PROBLEM: Multiply the contents of $\boldsymbol{A}$ by the absolute value of the number at address <code>ONEPRCNT.</code> | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------| | | FMU. MG GNEPRENT | | | 1 12 3 4 5 6 7 8 | 9 10[11]12[13]14[15]16[17]18[19]20[21]22[23]24[25]26[27]28[29]30[31]32[33]34 | <br> 35 36 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | #### The FLOATING DIVIDE Instruction The FLOATING DIVIDE instruction is an instruction that divides the contents of A by a 48-bit operand from an 18-bit storage address in floating point format. One memory reference is made. The 18-bit storage address is composed of a bank term $\underline{a}$ (within parentheses) and a modified base address $\underline{M}$ where $\underline{M} = \underline{m} + (\underline{B}^b) + (\underline{V}^v)$ . If the bank term is missing, the current operand bank setting is assumed. The b and v index designators allow for relative addressing. If they are not used, direct addressing is implied. If CM is specified by the programmer, the contents of A are divided by the complement of the operand at the storage address. If MG is specified by the programmer, the contents of A are divided by the magnitude (absolute value) of the operand at the storage address. Normally the coefficient is rounded if one-half or greater. If UR is specified by the programmer, rounding will not take place. The initial contents are of the Q register are always destroyed by this instruction. #### PROBLEM: Divide the contents of A by a floating point number at address DENOM. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------| | | FOV | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 10 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | 138 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Do a Floating Divide by the absolute value of the number at address PAR modified by Index Register 1. # SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|---------------------------------------------------------------------------------------------------------|----------| | | F.D.V. PAR.1 | | | 1 12 3 4 5 6 7 8 | 9 10[11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 3 | j<br> | ## PROBLEM: Do a Floating Divide using address CARC with unrounded arithmetic. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------|-------------------------------------| | | F.D.V. J.U.R. CARC | <u> </u> | | 1 2 3 4 5 6 7 8 | 9 10 111 12 13 14 15 16 17 18 19 20 21 22 23 24 25 126 127 128 129 130 131 132 1 | 33134135136137139139190141431414414 | # PROBLEM: Do a Floating Divide using the address specified in Index Registers $2 \ \mathrm{and} \ 3$ . | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------|----------| | | F.D.V | | | 1 2 3 4 5 6 7 8 | 10 [11, [12 [13 [14 [15 [16 [17] 18 [19 ] 20 [21] 22 [23 [24] 25 [26 [27] 28 [29 ] 30 [31 [32 [33 [4] | <br> | #### NEW CONCEPTS OF GROUP 14 Floating point arithmetic offers to most people the most troublesome arithmetic to work with. They can understand integer format. The octal numbers $0 \longrightarrow 013$ and $7 \longrightarrow 751$ in integer format offer no problem. They can understand fractional format The octal numbers $340 \longrightarrow 0$ and $727 \longrightarrow 7$ offer no problem. But a mixture of integers and fractions using floating point format loses many people completely. Some people memorize rules. Some people carry a rulebook with them. These methods are cumbersome and often forgetful. This portion of the section deals with floating point format including the operation and use of the floating point instructions. The method employed to show floating point format is based on the elementary rules of algebra. In order to understand floating point format, one needs to know; - 1. the difference of coefficient, base number, and exponent, and how changing signs of the coefficient and exponent changes the value of the number. - 2. the method we used in explaining integer and fractional formats. First of all, let's consider the format. In scientific notation all numbers can be expressed like the following: This means that some <u>coefficient</u> is multiplied by some <u>base</u> number raised to an exponent. Examples are: - $\frac{1}{1}$ . $1.5 \cdot 10^3$ - $2. -3.6 \cdot 10^5$ - 3. $7.1 \cdot 10^{-4}$ - $4. -6.8 \cdot 10^{-5}$ Here the base number is always 10 You may notice that the sign of the coefficient and the sign of the exponent are mixed. Let us rearrange these numbers from the largest to the smallest. They would be ordered like this: 1. $$1.5 \cdot 10^3$$ 2. $7.1 \cdot 10^{-4}$ Largest $3. -6.8 \cdot 10^{-5}$ 4. $-3.6 \cdot 10^5$ Smallest This we've learned from algebra. Note that the number with the positive coefficient and exponent is the largest and how the number with the negative coefficient and positive exponent is the smallest. Note also that a number above zero has a positive coefficient and a number below zero has a negative coefficient. Note also that the sign of the coefficient determines whether the number is positive or negative When numbers are expressed on the machine, they are expressed in binary with a base 2. If the base is always 2, there are two quantities which the format must express: the coefficient and the exponent. The engineers for the 3400/3600/3800 systems have formatted a floating point operand as such: Bits 47 and 35 -> 0 represent the coefficient. Bits 46 -> 36 represent the exponent. The coefficient is always represented as a fraction with the point assumed to be between bits 36 and 35. The sign of the fraction is bit 47. Now you ask, "Why have the sign of the coefficient as the uppermost bit?" The answer is that it is the sign of the coefficient which determines whether the complete operand is positive or negative. If it is out in front, it can nicely be checked by the AJP, PL or AJP, MI instruction as is done with the integer and fractional formats. Now let's return to algebra and see how binary numbers are expressed. We will use octal (easier to read) coefficients and exponents. Consider the numbers: $$1.\quad .\ 5\cdot\ 2^{6}$$ $$3. -.6 \cdot 2^{-7}$$ These numbers are already ordered from largest to smallest. Now let's say more about these numbers. - 1. represents a positive number greater than +1 - 2. represents a positive fraction - 3. represents a negative fraction - 4. represents a negative number less than -1 Now how do we match these numbers with how they look in machine format? Just as in integer and fractional formats, we draw a vertical number scale and compare positive forms only. We found that the largest number expressible in integer format was $37 \longrightarrow 7$ . We found that the largest number expressible in fractional format was $37 \longrightarrow 7$ . Would you believe the largest number expressible in floating point format is also $37 \longrightarrow 7$ ? It is because all formats are laid out the same. The smallest number expressible in all three formats is $40 \longrightarrow 0$ . Don't think though that you can mix formats and instructions at will during the program. The instruction and format of the operands must agree. From the scale it is apparent that any positive number greater than 1 will be between 20000 ----> 0 and 37777 ----> 7, and any positive fraction will be between 00000 ---> 0 and 20000 ---> 0. Examples below point out a few of the number conversions. | Algebraic Notation | | Computer Notation | |---------------------|---|----------------------------| | 1. $.5 \cdot 2^{6}$ | = | 200650> 0 | | $25 \cdot 2^{-6}$ | = | 177150 <del>→ &gt;</del> 0 | What about negative numbers? What is the computer notation for -. $5 \cdot 2^6$ ? If you remember integer and fractional formats, all we did was complement. From number 1 above $200650 \longrightarrow 0$ becomes $577127 \longrightarrow 7$ . This is the answer to the negative number, and of course, the sign shows negative. When the computer adds, subtracts, multiplies, or divides two floating point operands, it will always normalize and round the coefficient. This makes the answer as close as possible. However, the programmer may declare unnormalized or unrounded arithmetic for certain applicatives by specifying UN or UR respectively. #### POSSIBLE ERRORS The possible errors for the four floating point instructions include the following: # Instruction Fault 1. FAD Exponent Overflow - this occurs when the carry during the coefficient add causes the exponent to extend beyond 1777. 1777 octal is the maximum positive exponent allowed in the format. Exponent Underflow- this occurs when the carry during the coefficient add causes the exponent to extend beyond -1777. -1777 is the maximum negative exponent allowed in the format. - 2. FSB Same faults as above. - 3. FMU Same faults as above this occurs when the addition of the exponents causes the exponent to exceed 1777 for Overflow or -1777 for Underflow. 4. FDV Same as above - occurs when the exponents are subtracted. The re- sult must be between -1777 and 1777. Divide Fault - occurs when the divisor is zero. One further point on floating point operands is noted. If the computer answer results in zero, the answer will be $0 \longrightarrow 0$ . This is so that the AJP, ZR or AJP, NZ instruction can determine it as it can for integers or fractions. # Problem 14: A formula for Z states that $Z = .05(3X^2-2XY+Y^2)$ . Solve for Z if X and Y are given in floating point format. Problem 14 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIE | RS ADDRESS FIELD | COMMENTS | |-------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------------| | 1 12 2 2 14 15 14 17 14 | • up [ 13 12 13 34 15 16 17 30 19 | 20 21 27 20 20 25 24 27 26 27 26 21 22 20 21 22 20 24 27 26 27 26 27 26 | <br> | | | IDENT | EVAL | | | | ENTRY | EVAL | <br> | | 2 | BSS | 1 | | | SAVE | BSS | 14 | <u> </u> | | CONST | DEC | b 3. c. 9 c 05 | <u> </u> | | EVAL | BSS | <u> </u> | <u> </u> | | | LDA FMU | V | <u> </u> | | | FMU | CONST | 2×1, , _ , _ , _ , _ , _ , _ , _ , _ , | | | STA | SAVE | | | | LOA | X | | | | FMU | X | | | | FMU | COUST+1 | 3x**1 | | | FSB | SAUE | BX##2-2xy+y**2 | | | STA | SAVE | | | | LDA | 11 | 11.2 | | | FMU | <u> </u> | V**2 | | | FAD | SAVE<br>KONSTt2 | 3X**2-2XY+Y**2<br>FINAL EVALUATION | | | STA | E | | | | 5.4.7 | EVA4 | | | | FND | | | Somewhere within this subprogram would also be included the symbols X and Y in the location field with a declaration of the prestored data or area reserved. # Student Problem 14A: Solve for S if S = (p/q + 1)(r/2 - 3) and p, q, and r are given in floating point format. Flowchart: Problem 14A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------| | 212121412141714 | * 101/12/12/14/15/14/15/16/16/16 | 20 21 77 29 34 25 34 27 28 29 30 31 37 35 34 35 34 37 38 37 38 37 | District (41,44,44,44,44,46,58,531,53,54,55,54,55,54,54,54,44) 41,42,44,44,44,44,44,44,44,44,44,44,44,44, | | | 4 | <u> </u> | | | | | <u> </u> | | | | <del> </del> | | | | <u> </u> | <del> </del> | <u> </u> | | | | <del> </del> | <u> </u> | <del></del> | | | <del></del> | <u> </u> | | | | | <u> </u> | | | | | | <del></del> | | | | | <del>- </del> | | | | | | | | | <u> </u> | | | | | | <u>.</u><br>1 <u></u> | | | | <u> </u> | <u> </u> | | <del></del> | <del></del> | | !<br> | | | + | <u> </u> | | | | ++++++++ | | | | <del></del> | +++++++ | | | | $\vdash$ | | | <u> </u> | | | | <u> </u> | 1 | | | 1 | | | | | +++++++++ | | | GROUP 15 SEARCH ## **GROUP 15** #### SEARCH | 1. | Equality Search | EQS | |-----|--------------------------------|------| | 2. | Threshold Search | THS | | 3. | Masked Equality Search | MEQ | | 4. | Masked Threshold Search | MTH | | 5. | Search Equality | SEQU | | 6. | Search Masked Equality | SMEQ | | 7. | Search Within Limits | SEWL | | 8. | Search Magnitude Within Limits | SMWL | | 9. | Locate List Element Upper | LSTU | | 10. | Locate List Element Lower | LSTL | | 11. | Scan | SCAN | This group of instructions searches one or more storage words from memory until it has made a find, or until the specified list has been completely searched. One memory reference is required for each address searched. The first four instructions use an index register for the number of addresses to be searched. If a find is made, a full exit is taken. If no find is made, a half exit is taken. Because of this principle, these four instructions are upper instructions, and the computer assembler will force these instructions to the upper position. Therefore the programmer should not modify these instructions with modifiers, bank terms, or second index designators, since this overrides the assembler and makes the use of these instructions ineffective. The next four instructions make use of Index Registers 1, 2, and 3. By using Index Register 3 as an incrementer, some storage addresses can be skipped. The next two instructions locate an element within a list. This list must have been previously set up by the programmer, and now an element may be specified by its order in the list. The last instruction searches bytes of memory words rather than complete memory words. # The EQUALITY SEARCH Instruction The EQUALITY SEARCH instruction is an instruction that searches memory for an operand equal to the contents of A. One memory reference results for each storage address searched. The contents of the index register specified by $\underline{b}$ determine the number of storage addresses searched. For every address searched the contents of the index register are decremented by 1. If no index designator is specified, one word is searched at address m. ## PROBLEM: Examine the quantity at address KLUDGE for being equal to the contents of A. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | | E.Q.S. KLUDGE | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 3 | 1 4014 142 143 144 145 145 147 149 149 1 | PROBLEM: Given: $(B^1) = 100$ Search a table of 100 locations starting at address TAB for some quantity equal to A. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------| | | EQS TABOL | | | 1 2 3 4 5 6 7 8 | 9 10[11][2][3][4][5][6][7][8][9][20[21][22][23][24][25][26][27][28][29][30[31][32][33][34][35][3 | 6 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: $(B^2) = 100 \text{ octal}$ Search a table of 100 (octal) values starting at address MAT for some quantity equal to $\ensuremath{\text{A.}}$ # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|----------| | 11111 | Eas MAT, 2 | | | 1 2 3 4 5 6 7 8 | 9 | | # PROBLEM: Examine the quantity at address SMUT for being equal to the contents of A. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|----------| | | E.Q.S. S.M.U.T. | | | 1 2 3 4 5 6 7 6 | <br> | <br> | # The THRESHOLD SEARCH Instruction The THRESHOLD SEARCH instruction is an instruction that searches memory for an operand greater than the contents of A. One memory reference results for each storage address searched. The contents of the index register specified by $\underline{b}$ determine the number of storage addresses searched. For every address searched the contents of the index register are decremented by 1. If no index designator is specified, one word is searched at address m. # PROBLEM: Examine the quantity at address SMALLEST for being greater than the contents of A. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | | THS SMALLEST | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | ;<br>;37 38 39 40 41 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: $(B^3) = 5$ Search a Table of five values starting at address AREA for some quantity greater than A. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------| | | THS AREA 3 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 3 | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: $(B^4) = 100$ Search a table of 100 values starting at address TAR for some quantity greater than A. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------------------------------------|----------| | | THS | | | 1 2 3 4 5 6 7 8 | 9 10 [11 ] 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | | PROBLEM: Given: $(B^5) = 200$ Search a table of 200 values starting at address PATCH for some quantity greater than A. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------|-------------------------------------------| | | THIS PATCH.5 | | | 1 2 3 4 5 6 7 8 | 9 10 11 112 13 114 115 116 117 118 119 220 21 122 23 124 125 126 127 128 129 130 131 132 133 134 135 136 13 | 71381391401411421431441451461471481491501 | # The MASKED EQUALITY SEARCH Instruction The MASKED EQUALITY SEARCH instruction is an instruction that searches memory for an operand masked with the contents of Q that is equal to the contents of A. One memory reference results for each storage address searched. The contents of the index register specified by $\underline{b}$ determine the number of storage addresses searched. For every address searched the contents of the index register are decremented by 1. If no index designator is specified, one word is searched at address m. PROBLEM: Given: (Q) = 77 octal Examine the lowest six bits at address TAB for being equal to the contents of A. ## SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------|------------------------------------|----------| | | MEQ | i<br>1 | | 1 12 13 14 15 16 17 18 | <br> | | PROBLEM: Given: (Q) = 770 - 0 octal (B<sup>1</sup>) = 100 Search a table of 100 values starting at address ENT for some upper 6 bits equal to the contents of A. # SOLUTION: | LOCN | | OPERATION, MODIFIERS AÐDRESS FIELD | COMMENTS | |-----------------|---|------------------------------------------------------------------------------------|----------| | | | MEQ ENT. 1 | | | (12131415161718 | , | 10 [11 [12 [13 ]14 [15 ]16 [17 ]18 [19 ]20 [21 ]22 [23 ]24 [25 ]26 [27 ]28 [29 ]30 | <br> | Search a table of 10 values starting at address PETE for some lower half portion equal to A. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------|-----------------------------------------------------------------------------------------------------------|----------| | | MEQ. PETE, 2 | 1 | | 1 12 13 14 15 16 17 18 | 9 1011 1121314 115 116 117 118 119 20121 22123 24 225 26 1 27 28 1 29 1 30 1 31 1 32 1 33 1 3 4 1 35 1 36 | <br> | PROBLEM: Given: (Q) = $777\overline{7}77770$ —0 octal Examine the upper half of the value at address PAL for being equal to A. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------| | | MEQ | | | . [2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 [21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 37 38 39 40 4- 42 43 44 45 46 47 48 49 50 | #### The MASKED THRESHOLD SEARCH Instruction The MASKED THRESHOLD SEARCH instruction is an instruction that searches memory for an operand masked with the contents of Q that is greater than the contents of A. One memory reference results for each storage address searched. The contents of the index register specified by $\underline{b}$ determine the number of storage addresses searched. For every address searched the contents of the index register are decremented by 1. If no index designator is specified, one word is searched at address m. PROBLEM: Given: (Q) = 77 octal Examine the lowest six bits at address TUB for being greater than the contents of A. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|--------------------------------------------------------------------| | | M.T.H. | 1 | | 1 2 3 4 5 6 7 8 | <br> | 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: (Q) = 770 - 0 octal Examine the highest six bits at address TANK for being greater than the contents of A. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------| | | $M_1T_1H_1$ | 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | <br> 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 1 | | PROBLEM: Given: (Q) = 77 octal, $(B^4)$ = 10 Search a table of 10 values starting at address TOP to see if the lowest 6 bits of each value is greater than A. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------|-------------------------------------------------------------------------------------------|----------| | | MT.H. TOP.4 | | | 1 12 13 14 15 16 17 16 | 9 10 11 112 113 114 115 116 117 118 119 120121122123124125126 127128129130131 12713313413 | 1 | PROBLEM: Given: (Q) = 000777770 - 0 octal, (B<sup>5</sup>) = 20 Search a table of 20 values starting at address FORM to see if the upper address portion of each value is greater than A. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | | MITH FORM. 5 | | | 1 12 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 32 36 37 37 37 37 37 37 37 | | # The SEARCH EQUALITY Instruction The SEARCH EQUALITY instruction is an instruction that searches memory for an operand that is equal to the contents of A. One memory reference results for each storage address searched. Before this instruction is executed, three index registers are defined and must be set up as follows: - 1. (B<sup>1</sup>) number of storage words to search - 2. (B<sup>2</sup>) modifier for address m - 3. $(B^3)$ incrementer for $(B^2)$ The incrementer is set for 1 for searching sequential words, 2 for searching every other word, etc. The bank term <u>a</u> allows the programmer to search in any bank starting with address $\underline{M}$ where $M = m + (B^2)$ . If the search is satisfied, a full exit is taken. The address of the operand that satisfied the search will be given by $m + (B^2) - (B^3)$ . If the search is not satisfied, program control will transfer to address $\underline{n}$ with the contents of Index Register 1 going to zero. PROBLEM: Given: $(B^1) = 100$ , $(B^2) = 0$ , $(B^3) = 1$ Search a table of 100 values starting at address TAB in Bank 1 for some value equal to the contents of A. If the search is satisfied, continue the program. If not, jump to address NOFIND. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------| | | SEQU (1) TAB, NOFIND | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 3 | 61371381391401411421431441451461471481491501 | PROBLEM: Given: $(B^1) = 100$ , $(B^2) = 0$ , $(B^3) = 2$ Search a table of 200 values by searching only every other value (actually 100 values). The first address is MORT in Bank 2. If there is some value equal to A, continue the program. If not, jump to address NIL. # SOLUTION: | LOCN | OPERATION, MODIFIERS ABDRESS FIELD | COMMENTS | |---------------------------|------------------------------------------------------------------------------------------------------------------------|---------------------------------------| | | SEQU (2) MORT NIL | | | 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 [21] 22 123 124 125 126 127 128 129 130 [31 132 133 134 135 136 137 138 1 | 3914014: 1421431441451461471481491501 | PROBLEM: Given: $(B^1) = 10$ , $(B^2) = 0$ , $(B^3) = 1$ Search a table of 10 values starting at address PETE in the bank where PETE resides for some value equal to A. If the search is satisfied, continue the program. If not, jump to address NIX. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------|---------------------------------------------| | | SEQU (#) PETE NIX | | | 1 2 3 4 5 6 7 8 | 9 10]11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 35 34 35 31 | 6 37 38 39 40 4: 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: $(B^1) = 100$ , $(B^3) = 1$ Search a table of 100 values starting at the address specified in Index Register 2 in Bank 3 for some value equal to A. If the search is satisfied, continue the program. If not, jump to address RECALL | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |----------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | SEQU (3) RECALL | | | 12131415161718 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 79 30 31 32 33 34 35 36 3 | 7 38 39 40 41 42 43 44 45 46 47 48 49 50 | # The SEARCH MASKED EQUALITY Instruction The SEARCH MASKED EQUALITY instruction is an instruction that searches memory for an operand that, masked with the contents of Q, is equal to the contents of A. One memory reference results for each storage address searched. Before this instruction is executed, three index registers are defined and must be set up as follows: - 1. (B<sup>1</sup>) number of storage words to search - 2. $(B^2)$ modifier for address m - 3. $(B^3)$ incrementer for $(B^2)$ The incrementer is set for 1 for searching sequential words, 2 for searching every other word, etc. The bank term <u>a</u> allows the programmer to search in any bank starting with address <u>M</u> where $M = m + (B^2)$ . If the search is satisfied, a full exit is taken. The address of the operand that satisfied the search will be given by $m + (B^2) - (B^3)$ . If the search is not satisfied, program control will transfer to address $\underline{n}$ with the contents of Index Register 1 going to zero. PROBLEM: Given: $(B^1) = 100$ , $(B^2) = 0$ , $(B^3) = 1$ , (Q) = 77 octal Search a table of 100 values starting at address PACK in Bank 1 for some value whose lowest six bits are equal to the contents of A. If the search is satisfied, continue the program. If not, jump to address ERROR. ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------|-----------------------------------------| | | SMEQ (1) PACK, ERRØR | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 21 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 | <br> | PROBLEM: Given: $(B^1) = 100$ , $(B^2) = 0$ , $(B^3) = 2$ , (Q) = 770 - 0 Search a table of 200 values by searching only every other value (actually 100 values). The first address is SORT in Bank 2. If there is some value whose highest six bits are equal to A, continue the program. If not, jump to address PIL. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|----------| | | SMEQ (2) SPRIT PIL | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | <br> | PROBLEM: Given: $(B^1) = 10$ , $(B^2) = 0$ , $(B^3) = 1$ , (Q) = 77777 octal Search a table of 10 values starting at address SETE in the bank where SETE resides for some value whose lowest 15 bits are equal to A. If the search is satisfied, continue the program. If not, jump to address FIX. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------|------------------------------------------------| | | SMEQ (#) SETE, FIX | | | 1 2 3 4 5 6 7 1 | 8 9 10 [11] | 5 36 37 38 39 40 4: 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: $(B^1) = 100$ , $(B^3) = 1$ , (Q) = 777770 - 0 Search a table of 100 values starting at the address specified in Index Register 2 in Bank 3 for some value whose highest 15 bits are equal to A. If the search is satisfied, continue the program. If not, jump to address RECALL. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------|----------| | <u> </u> | SMEQ (3) 19 RECALL | ! | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10 111 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | <br> | # The SEARCH WITHIN LIMITS Instruction The SEARCH WITHIN LIMITS instruction is an instruction that searches memory for an operand that is greater than the contents of Q, but less than or equal to the contents of A. One memory reference results for each storage address searched. Before this instruction is executed, three index registers are defined and must be set up as follows: - 1. (B<sup>1</sup>) number of storage words to search - 2. $(B^2)$ modifier for address m - 3. $(B^3)$ incrementer for $(B^2)$ The incrementer is set for 1 for searching sequential words, 2 for searching every other word, etc. The bank term <u>a</u> allows the programmer to search in any bank starting with address $\underline{M}$ where $M = m + (B^2)$ . If the search is satisfied, a full exit is taken. The address of the operand that satisfies the search will be given by $m + (B^2) - (B^3)$ . If the search is not satisfied, program control will transfer to address $\underline{n}$ with the contents of Index Register 1 going to zero. PROBLEM: Given: $(B^1) = 100$ , $(B^2) = 0$ , $(B^3) = 1$ Search a table of 100 values starting at address FAB in Bank 1 for some value greater than Q, but less than or equal to the contents of A. If the search is satisfied, continue the program. If not, jump to address NOFIND. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIE | LD COMMENTS | |-------------------------------|----------------------------------|---------------------------------------------------------------------------| | | SEWL (1) FAB | $\mathcal{N}_{\bullet}$ | | 1 2 3 4 5 6 7 8 | , , , | 6,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50 | PROBLEM: Given: $(B^1) = 100$ , $(B^2) = 0$ , $(B^3) = 2$ Search a table of 200 values by searching only every other value (actually 100 values). The first address is MORT in Bank 2. If there is some value greater than Q, but less than or equal to A, continue the program. If not, jump to address NIL. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADD | DRESS FIELD | COMMENTS | |-----------------|--------------------------|-------------|------------------------------------------------------------------------------| | | SEWL (2) | MORTINIL | 1 | | 1 2 3 4 5 6 7 8 | | | 15 36 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: $(B^1) = 10$ , $(B^2) = 0$ , $(B^3) = 1$ Search a table of 10 values starting at address FETE in the bank where FETE resides for some value greater than Q, but less than or equal to A. If the search is satisfied, continue the program. If not, jump to address TIX. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------------|---------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------| | | SEWL (#) FETE, TIX | | | 1 2 1 3 1 4 1 5 1 6 1 | 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 3 | <br> 34 35 36 37 38 39 40 4. 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: $(B^1) = 100$ , $(B^3) = 1$ Search a table of 100 values starting at the address specified in Index Register 2 in Bank 3 for some value greater than Q, but less than or equal to A. If the search is satisfied, continue the program. If not, jump to address RECALL. | LOCN | 01 | PERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------|------------|----------------------------------------------|---------------|---------------------------------------------------------------------| | | 5 | $E_{\mathbf{W}}L_{\mathbf{L}}$ | (3), RECAL | L, , , , , , , , , , , , , , , , , , , | | 1 2 3 4 5 6 | 7 8 9 10 | 101 115 12 (13 14 15 16 17 18 19 | | 29[30[31]32[33]34[35[36]37[38]339[40]4 42[43]44[45[46]47[48]49[50] | ## The SEARCH MAGNITUDE WITHIN LIMITS Instruction The SEARCH MAGNITUDE WITHIN LIMITS instruction is an instruction that searches memory for an operand whose magnitude is greater than the contents of Q, but less than or equal to the contents of A. One memory reference results for each storage address searched. Before this instruction is executed, three index registers are defined and must be set up as follows: - 1. (B<sup>1</sup>) number of storage words to search - 2. (B<sup>2</sup>) modifier for address m - 3. $(B^3)$ incrementer for $(B^2)$ The incrementer is set for 1 for searching sequential words, 2 for searching every other word, etc. The bank term <u>a</u> allows the programmer to search in any bank starting with address $\underline{M}$ where $M = m + (B^2)$ . If the search is satisfied, a full exit is taken. The address of the operand that satisfied the search will be given by $m + (B^2) - (B^3)$ . If the search is not satisfied, program control will transfer to address $\underline{n}$ with the contents of Index Register 1 going to zero. PROBLEM: Given: $$(B^1) = 100$$ , $(B^2) = 0$ , $(B^3) = 1$ Search a table of 100 values starting at address TUB in Bank 1 for some value whose absolute value is greater than Q, but less than or equal to the contents of A. If the search is satisfied, continue the program. If not, jump to address SKIP. ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------| | | SMWL (L) TUB, SKIP | | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 37 38 39 40 41 42 43 44 45 45 47 48 49 50 | PROBLEM: Given: $(B^1) = 100$ , $(B^2) = 0$ , $(B^3) = 2$ Search a table of 200 values by searching only every other value (actually 100 values). The first address is TORT in Bank 2. If there is some value whose absolute value is greater than Q, but less than or equal to A, continue the program. If not, jump to SOLUTION: address SIL. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------|----------------------------------------------------------------| | | $S_{M,W,L}$ (2) $T_{M,R,T,2}S_{I,L}$ | | | 1 2 3 4 5 6 7 8 | 9 10[11][12]13[14]15[16]17[18]19[20[21]22]23[24]25[26[27]28[29]30[31]32[33]34]35[36[37]3 | 38 39 40 41 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: $(B^1) = 10$ , $(B^2) = 0$ , $(B^3) = 1$ Search a table of 10 values starting at address KATE in the bank where KATE resides for some value whose absolute value is greater than Q, but less than or equal to A. If the search is satisfied, continue the program. If not, jump to address SIX. # SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------|-------------------------------------------------------| | | $S_{MWL}$ $(#)KATE,SIX$ | 1 | | | 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | <del></del> | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 6 | 9 10 [11 [12] 13 [14] 15 [16] 17 [18] 19 [20] 21 [22] 23 [24] 25 [26] 27 [28 [29] 30 [31 [32] 33 [34] 3 | ,<br>351361371381391401411421431441451461471481491501 | PROBLEM: Given: $(B^1) = 100$ , $(B^3) = 1$ Search a table of 100 values starting at the address specified in Index Register 2 in Bank 3 for some value whose absolute value is greater than Q, but less than or equal to A. If the search is satisfied, continue the program. If not, jump to address PUNT. | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------| | | SMWL (3), PUN,T | | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10 11 12 13 14 15 16 17 10 19 20 21 22 23 24 25 26 27 20 29 30 31 32 33 34 35 3 | 613713813914014: 1421431441451461471481491501 | # The LOCATE LIST ELEMENT (UPPER) Instruction The LOCATE LIST ELEMENT (UPPER) instruction is an instruction that reads from memory one element from a list of elements. No processing is done on the element with this instruction. This instruction, however, gives the needed information in order to process the element with future instructions. An element is a word or a group of words usually in sequential order. A list is a set of elements. If a programmer's list of elements is in memory, he can call out any element of the list with this instruction. The machine does it by referencing the upper address portion of the beginning of each element in order to arrive at the next element of the list. At the end of the instruction the address of the element he wanted will be in the index register specified by $\underline{v}$ and the bank term will be contained in the operand bank setting. With this information he can process the element with future instructions. The programmer calls out an element with this instruction by first entering the index register specified by $\underline{b}$ with the $n^{th}$ element he wants minus 1; i.e., if he wants to work with the 5th element, he enters the index register with 4 since after 4 iterations in the hardware, he will have the address of the 5th element in Index Register $\underline{v}$ . In Index Register $\underline{v}$ he enters initially the address of the first element. With these two specifications (both a must), the hardware iterates until the address of his element is in the index register specified by v. This instruction is especially important when a list is 200 elements or more. He can call the 247th element from the list without having to remember the address each time. PROBLEM: Given: $(B^1) = 35$ , $(B^2) = START$ Locate the 36th element of the list starting at address START. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------| | | LSTU ZZZ | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | | PROBLEM: Given: $(B^2) = 498$ , $(B^3) = BEGIN$ Locate the 499th element of the list starting at address BEGIN. ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------| | | LSTU 223 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 1 | <br> 32 33 34 35 36 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: $(B^4) = 503$ Locate the 504th element of a list starting at the address specified in Index Register 5. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------| | | L S T U 4 5 5 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 3 | 81391401411421431441451461471481491501 | PROBLEM: Given: $(B^6)$ = ENTER Locate the nth element minus one (in Index Register 5) starting at address ENTER. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | LSTU 51,6 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | ### The LOCATE LIST ELEMENT (LOWER) Instruction The LOCATE LIST ELEMENT (LOWER) instruction is an instruction that reads from memory one element from a list of elements. No processing is done on the element with this instruction. This instruction, however, gives the needed information in order to process the element with future instructions. An element is a word or a group of words usually in sequential order. A list is a set of elements. If a programmer's list of elements is in memory, he can call out any element of the list with this instruction. The machine does it by referencing the lower address portion of the beginning of each element in order to arrive at the next element of the list. At the end of the instruction the address of the element he wanted will be in the index register specified by $\underline{v}$ and the bank term will be contained in the operand bank setting. With this information he can process the element with future instructions. The programmer calls out an element with this instruction by first entering the index register specified by $\underline{b}$ with the $n^{th}$ element he wants minus 1; i.e., if he wants to work with the 5th element, he enters the index register with 4 since after 4 iterations in the hardware, he will have the address of the 5th element in index register $\underline{v}$ . In Index Register v he initially enters the address of the first element. With these two specifications (both a must), the harde are iterates until the address of his element is in the index register specified by v. This instruction is especially important when a list is 200 elements or more. He can call the 247th element from the list without having to remember the address each time. PROBLEM: Given: $(B^1) = 39$ , $(B^2) = INIT$ . Locate the 40th element of a list starting at address INIT. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------|------------------------------------------| | | LSTL 1,2 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 | 38 39 40 41 42 43 44 45 46 47 48 49 50 1 | PROBLEM: Given: $(B^3) = 5003$ , $(B^4) = GO$ . Locate the 5004th element of a list starting at address GO. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|-------------------------------------------------------------------------------------------------|---------------------------------| | | LSTL 334 | 1 | | 1 12 3 4 5 6 7 8 | 9 10 111 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 46 | 0 4 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: $(B^5) = 496$ Locate the 497th element of a list starting at an address specified in Index Register 6. ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------| | | L,S,T,L, 5,3,6 | 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 [2 ] 3 ] 4 [ 5 ] 6 ] 7 [ 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | 3914014:142143144145145147148149150. | PROBLEM: Given: $(B^6) = COMMENCE$ Locate the nth element minue one (in Index Register 4) of a list starting at address COMMENCE. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------|----------------------------------------------------------|----------| | | L.S.T.L. 4,9,6 | 1 | | 1 12 13 14 15 16 17 18 | a noth instrative fire fire fire fire fire fire fire fir | <br> | #### The SCAN Instruction The SCAN instruction is an instruction that compares "bytes" of memory words with a byte in the Q register. The comparisons made are for equality, greater than, less than, not equal, less than or equal, and greater than or equal. One and only one of these must be specified by the programmer. Before the instruction is executed the A register must contain the byte count, i.e., the number of bytes that are to be scanned. Also the index register specified by $\underline{v}$ must contain the off-set designator for the memory word, i.e., the right-most bit position of the byte in memory where the scan is to start. Within the instruction $Q_0$ must be specified where $\underline{o}$ is the off-set designator for Q, i.e., the right-most bit position for the byte in Q. The modifier Ee represents the byte size, i.e., the width of the byte scanned. The letter <u>e</u> represents the number of bit positions. E6 would represent a 6-bit byte. The first address searched is $\underline{M}$ where $M = m + (B^b)$ . The scan continues through memory until the search is satisfied or until the byte count is exhausted. If the search is satisfied, program control transfers to (P) + 2. If the search is not satisfied, program control transfers to (P) + 1. PROBLEM: Given: (A) = 16, (B $^1$ ) = 0, (B $^2$ ) = 42, (Q) = 33 octal Scan a set of 16 6-bit characters starting at address KIT for being equal to 33 octal. #### SOLUTION: | LOCN | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------|-------------------------------------------|---------------------------------------------------------| | | S.C.AN, Q.O, E.6 | , Ε,Q, K,I,T,, 1, 2, 1, 1 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 | 20 21 22 23 24 25 26 27 28 29 30 31 32 33 | <br> 34 35 36 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: (A) = 50, (B<sup>1</sup>) = 0, (B<sup>2</sup>) = 24, (Q) = 0—04563 octal Scan a set of 50 24-bit quantities starting at address KOKO for something less than or equal to 4563 octal. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------|----------| | | SICAN, QO, E24, LE KOKO, 1,22 | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 1 | PROBLEM: Given: (A) = 1000, (B<sup>1</sup>) = 0, (B<sup>2</sup>) = 24, (Q) = 12345Scan a set of 1000 24-bit quantities starting at address PORT for something greater than or equal to 12345. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------------------------------------------------|----------| | | S.C.A.N., Q.O, E.Z.4, GE P. P. Q.R.T., 12, 12, | ! | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | 1 | PROBLEM: Given: (A) = 32, (B $^1$ ) = 0, (B $^2$ ) = 42, (Q) = XX0—0 Scan a set of 32 6-bit characters starting at address SORT for some character less than XX. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |---------------|-------------------------------------------------------------------------------------------------------------------------------|----------| | | S.C.AN, Q.4.2, E.B., L.T. S. Ø. R.T., 1, 2 | | | 1 2 3 4 5 6 7 | 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 3 | 1 | ## NEW CONCEPTS OF GROUP 15 The search instructions search a table of one or more memory words to find a word that satisfies a given condition. If a word is found, the search terminates and an exit is taken. The programmer can then determine what address satisfied the search. If a word is not found, the search terminates and a different exit is taken. The programmer can then record that the search was not satisfied. ## Problem 15: Assume a random set of 1000 floating point operands ranging from -100 to † 100 resides in memory starting at address TESTCASE. Write a subprogram that will store all values between -. 05 and +. 05 in a table starting at address TOLRANCE. Assume less than 10 of these. Problem 15 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 1 12 13 14 (3 14 17 14 | • 10 ; 11 ; 17 ; 13 ; 14 ; 15 ; 16 ; 17 ; 18 ; 19 | 20 [21 [72 ] 25 [26 : 25 ] 26 : 27 ] 78 [ 25 : 36 ] 31 32 : 33 34 : 27 ] 36 : 27 ] 36 : 27 ] 46 | 41 (42 43 44 45 44 47 44 47 55 53 53 53 54 55 55 57 58 57 58 51 57 52 54 55 55 55 55 55 55 | | | IDENT | RESISTAR | | | | ENTRY | RESISTAR | | | CONST | DEC | 052-05 | | | TOLRANCE | 1 | 1,0 | | | RESISTOR | BSS | <u> </u> | | | i | | 0,4 | TOLRANCE POINTER | | | | 20002 | WE DE WERDS | | | ENI | 0,2 | M+(B2) IS FWA | | | | 1,3 | SEQUENTIAL INCREMENTER | | | LOA | CONST+1 | UPPER LIMIT | | | KDQ | CONST | LOWER LIMIT | | CONSRCH | SEWL | TESTCASE, RESISTOR | | | | | A. D. L. | SAVE | | | | TESTCASE-1,2 | SATISFIED OPERAND | | 11111 | STA | TOLRANCE, 4 | | | | INI | 1.9.4 | BUMP PAINTER | | 44444 | T | D A | RESTORE | | | S4J | CONSPICH | 1 | | | END | | <u> </u> | | | | <u> </u> | <u> </u> | Somewhere within this subprogram would also be included the symbol TESTCASE in the location field with a declaration of the prestored data or area reserved. ## Student Problem 15A: A list of 1000 integer operands ranging from 1 - 100 reside in memory starting at address PEOPLE. Write a subprogram that will count the number of integers between 18 and 35. Store this count at address DRAFTABL. Flowchart: Problem 15A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |----------|--------------------------------------------------|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------| | | 18 17 18 18 19 19 18 18 18 18 | 11 72 23 3 24 25 24 27 78 27 30 31 32 13 24 25 24 27 38 17 40 | 41.1421.431.441.451.441.471.441.481.881.531.531.531.531.541.581.581.581.581.581.661.641.641.641.641.641.641.641.641.64 | | | | <u> </u> | <u> </u> | | | <del> </del> | | | | | <del> </del> | | | | | <del> </del> | <del></del> | <u> </u> | | | | <u> </u> | | | | <del> </del> | | | | | | | <u> </u> | | | | <u></u> | | | <u> </u> | <u> </u> | | | | | | <del></del> | | | | <del> </del> | | | | | <del></del> | | | | | <del></del> | <del></del> | | | | <del> </del> | | | | | | <del></del> | <u> </u> | | | <u> </u> | | | | 444444 | <u> </u> | <u> </u> | | | | <del> </del> | | | | | | | | | | <b> </b> | | . di di dan manda di manana di manana manana manana di manana di manana di manana di manana di manana di manana | ## GROUP 16 ## STORAGE TEST ## GROUP 16 ### STORAGE TEST Storage Skip Storage Shift SSK SSH This group of instructions checks the contents of a storage address for being positive or negative. If positive (false, no), a half exit is taken. If negative (true, yes), a full exit is taken. Because of this principle, these two instructions are upper instructions, and the computer assembler will force them to the upper position. Therefore the programmer should not modify these instructions with modifiers, bank terms, or second index designators since this overrides the assembler and makes the use of these instructions ineffective. The second instruction is just like the first; however, the contents of the storage address are left shifted by one after the check. ## The STORAGE SKIP Instruction The STORAGE SKIP instruction is an instruction that checks the contents of a storage address for a negative quantity. This storage address is composed of a modified base address $\underline{M}$ where $\underline{M}$ = $\underline{m}$ + ( $\underline{B}^b$ ). One memory reference is made. If the contents of the storage address are negative, a full exit is taken. If the contents are positive, a half exit is taken. The instruction leaves the contents of the storage address unchanged. ### PROBLEM: Check the contents of address ANS. If negative, full exit. If positive, half exit. ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------------------------------------|-------------------------------------| | | SSK ANS | | | 1 1 2 3 4 5 6 7 8 | 9 10 11 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 | 39 40 4+ 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Check the contents of address BEATLE modified by Index Register 4. If negative, full exit. If positive, half exit. ### SOLUTION: | LOCN | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | | |-------------------------------|-----------------------------------------------------|---------------|----------|--| | 1 1 1 1 1 1 1 | SSK | BEATLE | | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 15 | i | <br> | | ## PROBLEM: Check the contents of the address specified in Index Register 5. If negative, full exit. If positive, half exit. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------------|-------------------------| | | S.S.K. | 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 112 13 14 15 16 17 18 19 120 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | <br> | ## PROBLEM: Check the contents of address SLINK in the bank where the SSK resides. If negative, full exit. If positive, half exit. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------|----------| | | SSK (*) SLINK | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 20 21 22 23 24 25 26 27 28 29 | <br> | ## The STORAGE SHIFT Instruction The STORAGE SHIFT instruction is an instruction that checks the contents of a storage address for a negative quantity. This storage address is composed of a modified base address $\underline{M}$ where $\underline{M}$ = $\underline{m}$ + ( $\underline{B}^b$ ). One memory reference is made. If the contents of the storage address are negative, a full exit is taken. If the contents are positive, a half exit is taken. In either case, the contents of the storage address are left-shifted one binary position, end around. ### PROBLEM: Examine the contents of address SWITCH. If negative, full exit. If positive, half exit. In either case, shift the contents. ### SOLUTION: | LOCN | OPERATION, M | ODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------|------------------------|-----------------------------------------| | | S <sub>1</sub> S <sub>1</sub> H <sub>1 1 1</sub> | SWITCH | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 10 11 12 13 14 15 | <br> | <br> | ### PROBLEM: Examine the contents of address SWITCH modified by Index Registers 2 and 3. If negative, full exit. If positive, half exit. In either case, shift the contents. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | | S.S.H. S.W.I.T.C.H. 2,23 | | | 1 ] 2 3 4 5 6 7 8 | 9 .00 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 20 12 23 24 25 | 5;36;57;36;59;40;4-;42;43;44;45;46;47;48;49;50; | #### PROBLEM: Examine the contents of the address specified in Index Register 4. If negative, full exit. If positive, half exit. In either case, shift the contents of the address. ### SOLUTION: | LOCN | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |---------------------------|---|-------------------------------------------------|----------------------------------------|----------------------------------------------------------------------| | <u> </u> | - | S <sub>1</sub> S <sub>1</sub> H <sub>1</sub> | 9141111111 | : | | 1 2 2 3 4 1 5 1 6 1 7 1 8 | 9 | 10 11 12 13 14 15 16 17 18 19 | 20 21 22 23 24 25 26 27 28 29 | ;<br>;30[3:[32[33]34[35]36;37;38]39[40[4];42[43]44[45[46]47[48:49]50 | #### PROBLEM: Examine the contents of address PEACH in the bank where PEACH resides. If negative, full exit. If positive, half exit. In either case, shift left by 1 the contents of the address. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------| | | S.S.H. (#) P.E.A.C.H. | 11 | | 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 | 9 10 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 (50 13 - (32 13 | 1<br>3144135136 37:3813914014 ,42143144:45146147148,49150 | ## NEW CONCEPTS OF GROUP 16 No new concepts are presented here except that the programmer can use these instructions to branch to different points in his program. The second instruction automatically changes the transfer point at the discretion of the programmer. ## Problem 16: Generate starting at address NUM the first 1000 positive integers that are not divisible by 2 or 3. ## Flowchart: \* Switch Starts Out Even Problem 16 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------|----------| | 1 2 3 6 3 6 7 8 | 9 10 (21) (27 (13 (14 (15 (14 (17 (19 (19 ) | 30 j.2) ; 72 j.20 j.2+ j.25 j.2+ j.27 j.20 j.20 j.30 j.31 j.32 j.33 j.34 j.35 j.24 j.37 j.38 j.27 j.38 | <br> | | | | SENERATE | <u> </u> | | | | GENERATE | | | WUM. | | 1000 | | | SWITCH | | 25252525252525 | | | GENERATE | 1 | 1 | | | | EMI | <i>2</i> | | | | ENA | 7 | | | CKSWTCH | | SWITCH | | | 41111111 | | 57 | | | | INA | 4 | | | | | Vum, 1 | <u></u> | | | | 2 | | | CKCNT | | 999,1 | | | 111111 | | CKSWTCH | | | | | GENERATE | | | ST | | NUM21 | | | | END | <u>SKSMIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII</u> | | | | $\nu \nu \nu$ | | | ## Student Problem 16A: Generate starting at address NUM a table of integers with the following pattern: Flowchart: # Problem 16A would be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------| | . 12 12 14 12 14 17 14 | 9 10 11 12 113 14 1 (5 14 17 14 19 20 12) ; | 22 25 26 26 27 26 27 26 31 32 33 34 35 36 37 38 37 38 | 41, 42, 43, 44, 45, 44, 47, 44, 47, 56, 55, 53, 53, 54, 55, 56, 57, 58, 58, 60, 40, 43, 44, 45, 46, 46, 46, 46, 78, 71, 72, | | <u> </u> | <del> </del> | | <u> </u> | | <del></del> | <del> </del> | | | | | | | | | | <del> </del> | | | | | | | | | | <del></del> | | | | | | | | | | | | | | | 1 | | | | | | | | | | + | | | | | | | | | | <del> </del> | | | | | <del> </del> | | | | | <del> </del> | | <u> </u> | | | <del> </del> | | | | | <del> </del> | | | | <del></del> | 4 | | | ## GROUP 17 ## VARIABLE DATA FIELD TRANSMISSION #### GROUP 17 ## VARIABLE DATA FIELD TRANSMISSION Load Byte Store Byte LBYT SBYT This group of instructions transmits a byte of a word either from memory to an operational register (A or Q), or from an operational register to memory. One memory reference is required. The byte size is variable as well as its position in the word. If no indexing is specified, a full exit is taken after the transmission. If indexing is specified, the type of exit is determined by the amount of storage word left. If sufficient room is left for another byte, a skip exit is taken. If insufficient room is left, a full exit is taken whereupon the programmer has the opportunity to change the relative index counter and restore the memory off-set designator for the next word. ## The LOAD BYTE Instruction The LOAD BYTE instruction is an instruction that transmits a "byte" of a memory word from an 18-bit storage address to the A or Q register, whichever is specified. One memory reference is made. The 18-bit address is composed of the operand bank setting and $\underline{M}$ where $M = m + (B^b)$ . The operation leaves the contents of the storage address unchanged. The byte portion of the memory word replaces the byte portion of the specified register. The modifier Ao or Qo, one of which must be specified, represents the destination register. The o following it is the off-set designator for the register, i.e., the right-most bit position of the byte in the register. For example, if the upper half of the A register is to be filled, the specification would be A24. The letter o ranges from 0 to 47. The modifier Ee represents the byte size, i.e., the width of the byte transferred. The letter e represents the number of bit positions. For example, a byte size of 24 would be specified as E24. The letter e ranges from 1 to 48. The contents of the index register specified by $\underline{v}$ represent the off-set designator for the memory word, i.e., the right-most bit position of the byte in the memory word. For example, if the byte is to come from the lower half of a memory word, the contents of the index register $\underline{v}$ would be zero. If the programmer specifies CL, the <u>destination</u> will be cleared before the byte is inserted. In this instruction it would be either A or Q. If the programmer specifies LI or RI, automatic indexing takes place with respect to the off-set designator for the memory word. This is used to unpack bytes in memory. A full exit is taken if LI or RI is not specified. If either is specified, a full exit is taken when the off-set designator finishes with a memory word, and a skip exit, (P) + 2, is taken when a memory word is not finished. PROBLEM: Given: $(B^2) = 42$ Load the highest 6 bits from address SMOKEY into the lowest portion of A clearing the rest of A. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------|----------| | | LBYT, AO, EL SMOKEY, | | | 1 2 3 4 5 6 7 8 | 9 10 11 112 13 14 15 16 17 18 19 120 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 1 | <br> | PROBLEM: Given: $(B^2) = 24$ Load the upper address portion of the memory word at address SOAK into the lower address portion of the Q register without clearing the rest of Q. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------------------------------------------------------------------------------|----------| | | LBYT, RO, E15 SpAK, 222 | | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 [21 122 [23 ] 24 [25 ] 26 [27 ] 28 [29 ] 30 [31 32 ] 33 [34 ] 35 [36 ] 37 [38 | | #### PROBLEM: Load the right-most BCD character at address POKE modified by Index Register 3 into the lowest portion of A without clearing the rest of A. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------|----------------------------------------------------| | | LBYT, AO, EG POKE, 3 | | | 1 2 3 4 5 6 7 8 | <br> | ;<br>36;37;38;39;40;4·;42;43;44;45;46;47;48;49;50; | PROBLEM: Given: $(B^2) = 42$ Load the highest BCD character at address BUTT modified by Index Register 1 into the bottom part of A clearing the rest of A. Specify right indexing. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------|---------------------------------------------| | | LBYT, AO, EG, RI, CL BUTT, 1,2 | | | 1 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 13 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 3 | 6 37 38 39 40 4 42 43 44 45 46 47 48 49 50 | #### The STORE BYTE Instruction The STORE BYTE instruction is an instruction that transmits a "byte" of the A or Q register, whichever is specified, to a memory word at an 18-bit storage address. One memory reference is made. The 18-bit address is composed of the operand bank setting and $\underline{M}$ where $M = m + (B^b)$ . The operation leaves the contents of the register unchanged. The byte portion of the register replaces the byte portion of the memory word. The modifier Ao or Qo, one of which must be specified, represents the source register. The of following it is the off-set designator for the register, i.e., the right-most bit position of the byte in the register. For example, if the upper half of the A register is the source byte, the specification would be A24. The letter o ranges from 0 to 47. The modifier Ee represents the byte size, i.e., the width of the byte transferred. The letter $\underline{e}$ represents the number of bit positions. For example, a byte size of 24 would be specified as E24. The letter $\underline{e}$ ranges from 1 to 48. The contents of the index register specified by $\underline{v}$ represent the off-set designator for the memory word, i.e., the right-most bit position of the byte in the memory word. For example, if the byte is to be transferred to the lower half of a memory word, the contents of the index register $\underline{v}$ would be zero. If the programmer specifies CL, the <u>destination</u> will be cleared before the byte is inserted. In this instruction it would be the memory word. If the programmer specifies LI or RI, automatic indexing takes place with respect to the off-set designator for the memory word. This is used to pack bytes in memory. A full exit is taken if LI or RI is not specified. If either is specified, a full exit is taken when the off-set designator finishes with a memory word, and a skip exit, (P) + 2 is taken when a memory word is not finished. PROBLEM: Given: $(B^2) = 42$ Store the lowest BCD character from A in the highest portion of the word at address SLINKY leaving the rest of the memory word untouched. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------| | ·<br><del>- </del> | S.B.Y.T., A.O., E.6 S.L.I.N.K.Y. | 1 | | 1 2 3 4 5 6 3 | 7 8 9 10 11 12 13 14 15 16 17 18 19420 21 22 23 24 25 26 27 28 29 30 31 32 3 | 3 3 4 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Store the upper address portion of Q in the lower address portion of the word at an address specified in Index Register 3 clearing the rest of the memory word. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------| | | SBYT, Q. 2.4, E 1.5, C.L. 9.3 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 3 | 38 39 40 41 42 43 44 45 46 47 48 49 50 | PROBLEM: Given: $(B^2) = 24$ Store the lower address portion of Q in the upper address portion of the word at address SULKY without clearing the rest of the memory word. Specify right indexing. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------|----------| | | S.B.Y.T. , R.O. , E.I. S. U.L. K.Y. , , 2 | 1 | | 1 2 3 4 5 6 7 1 | 8 9 10 111 112 13 14 115 116 117 18 119 20 21 22 23 24 25 26 27 28 29 30 31 32 23 33 3 | | PROBLEM: Given: $(B^4) = 0$ Store the lower address portion of Q in the lower address portion of the word at address SLIP modified by Index Register 2 without clearing the rest of the memory word. Specify left indexing. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |---------------------|----------------------------------------------------------------------------------------------|----------------------------------------------| | | SBYT, RO, E15, LI, SLIP, 2, 4 | i<br>4 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 12 13 14 15 16 17 | 8 9 10 11: 12 13 14 15 16 17 18 19 12012 122 123 (24 125 126 127 128 129 130 131 132 133 134 | 4135 36 37 18 30 40 | ## NEW CONCEPTS OF GROUP 17 The principle of the LBYT and SBYT instructions should offer no more of a problem than the LDA and STA instructions. The BYTE instructions transmit one byte from memory to a register or from a register to memory, and exits. The only problem is the setting up of the instruction so that it does what the programmer wants it to do. Since a portion of a word can be transmitted, there are several definitions which one must know. These apply to both instructions. - 1. Index designator $\underline{v}$ where $(V^{V})$ represents the off-set designator i.e., the rightmost bit position of the byte of the memory word. - 2. Le where e represents the width of the byte (number of bits). - 3. As or Qo where o represents the off-set designator for the A or Q register i.e., the rightmost bit position of the byte in A or Q (one of them must be specified). With this information let's present a case, and then show the instruction (s) needed. Suppose we wish to transmit the upper address portion of a memory word (address M) to the lower address portion of A. What is the instruction (s) needed? The LBYT instruction is needed here and the instruction set looks like the following: ENI 24, 1 LBYT, A0, E15 M,, 1 The byte is inserted into the lower portion of A and the rest of A remains unchanged. If the programmer would like the rest of A cleared, he can specify <u>CL</u> in the operation field. <u>CL</u> will clear the destination word as the byte is transferring. After the LBYT, a full exit is taken to the next instruction. How would you transmit the byte in the reverse direction? The only change would be SBYT instead of LBYT. Now what about LEFT INDEX and RIGHT INDEXING? If LI or RI is specified, the memory off-set designator becomes a movable pointer and is automatically checked every time the instruction is executed. A general flowchart will help clear up this concept. One instruction will check all of the following: Everything in the flowchart is checked for in the hardware. The reason for normal exiting or skip exiting when indexing is specified, is that the normal exit allows the programmer to re-establish the memory pointer (W) and to advance or decrement the relative address counter (B<sup>b</sup>) before going on with the program. ## Problem 17: Assume a card image is in memory starting at address CARD. The card is in internal BCD and takes up 10 memory locations. Assume a set of parameters on the card, each 1-8 characters, each separated by a comma, and the set terminated by a period. Write a subprogram that will store each parameter, right justified with zero fill starting at address PARAM. Ignore blanks and assume less than 20 parameters. The internal BCD code for a blank is 60B, a comma is 73B, and a period is 33B. #### Flowchart: Problem 17 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIES | RS ADDRESS FIELD | COMMENTS | |------------------------|--------------------------------------------------|------------------------------------------|----------------------------------------------| | 1 12 13 14 13 14 17 14 | 9 10 11 17 13 14 15 M 17 10 10 | <br> | <br> | | | TDENT | PARAMONT | <u> </u><br> | | | ENTRY | PARAMONT | | | PARAM | | 20 | | | PARAMONT | BSS | 14:11:11:11:11:11:11:11:11:11:11:11:11:1 | | | | ENA | ho | | | | | $\rho_{\mathbf{j}}\mathbf{j}$ | | | | | P <sub>2</sub> 2 | <u> </u> | | | | 42,3 | | | READCHAR | | RI, C.L. CARD, 2,3 | | | | ENT | i i | EXECUTED ANLY WHEN FINISHED | | | TWI | 1.2. | WITH A MEMORY WORD | | 11111 | RGJP, EQ | R573B2COMMA | COMMA | | | RGJP, EQ | R360B3*-3 | BLANK, READ NEXT CHARACTER | | | | Q,338, PERJØD | IPERJAO. | | | QLS | 14.2 | [CII 0 0 0 0 0 0 1 | | | LLS | 10.54 - 6.44.2 | CHARACTER TO A | | | | READCHAR | | | CAMMA | | PARAM <sub>2</sub> 1 | STARE PARAMETER | | | INI. | <del>2,</del> <u>1</u> | <u> </u> | | | FNA | 10 54004440 | <u> </u> | | 0-0-40 | 1 1 | READCHAR | | | PERIØD | STA | PARAMONT | | | | 547 | I NEARCH ! | | | | END | <del></del> | | Somewhere within this subprogram would also be included the symbol CARD in the location field with a declaration of the prestored data or area reserved. ## Student Problem 17A: Assume the same problem as just given except the card image was read in backwards. In other words column 1 is the last character at address CARD+9 and column 80 is the first character at address CARD. Flowchart: # Problem 17A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------------------------------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | 18 (31 (17 (18 (18 (18 (18 (18 (18 (18 (18 (18 (18 | <br> | | | | <u> </u> | | $\vdash$ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u></u> | | | <del> </del> | | | | | | | | | | | | | | | | | | | 4 4 4 1 1 4 4 | | | | 1 1 1 1 1 1 1 | | | | | | | | | | | | 4444 | | and the short of the same t | | | <del></del> | | | | | | ## GROUP 18 INPUT/OUTPUT #### GROUP 18 ## INPUT/OUTPUT | 1. | Connect | CONN | |----|-------------------|-----------------------| | 2. | External Function | $\operatorname{EXTF}$ | | 3. | Begin Read | BEGR | | 4. | Begin Write | ${\tt BEGW}$ | | 5. | Copy Status | COPY | | 6. | Clear Channel | CLCH | | 7. | Input to A | IPA | This group of instructions works with the I/O equipment in the system. The first four instructions contain a "reject jump address" in case the operation cannot be performed. The first instruction opens a line from a data channel to a unit. The second instruction performs any one of a number of operations on the unit except reading or writing. The third and fourth instructions actually initiate the read or write operation which is completely buffered. The fifth instruction interrogates the operation on a data channel and can do so at any time. The sixth instruction clears all channel control and terminates any operation being performed on the channel. The last instruction is the only 24-bit instruction in the group. It inputs information from either the typewriter or card reader, whichever is selected (manual). The input is not buffered, i.e., program control will stop until the information is received. #### The CONNECT Instruction The CONNECT instruction is an instruction that connects one controller and one unit of that controller to a data channel. The designator $\underline{x}$ specifies the number of the data channel. The designator $\underline{e}$ specifies the number of the equipment (controller). The designator $\underline{u}$ specifies the number of the unit. The designator $\underline{n}$ specifies the Reject Jump Address if the connection cannot be made. If the connection can be made, it will be made and program control will go to the next instruction at (P) + 1. If the channel or unit is busy, program control will transfer to address $\underline{n}$ . If the channel or controller or unit is not present, an interrupt condition occurs. This is called the Internal Reject Interrupt. After going through the interrupt routine, program control will then go to address n. Connect to Data Channel 2, equipment 3 and unit 5. If the connection cannot be made, jump to address REJ. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|---------------------------------------------------| | | C. Ø. N. N. 2, 3, 5, 3, R. E. J. | <u> </u> | | 1 2 3 4 5 6 7 8 | | 4 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Connect to Data Channel 0, equipment 6 and unit 4. If the connection cannot be made, jump to address BUS. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------|-----------------------------------------| | | C. Ø. N. N. 1 26 2 4 2 B. U.S. | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 11: 1:2 1:3 1:4 1:5 1:6 1:7 1:8 1:9 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 | | ## PROBLEM: Connect to Data Channel 1, equipment 3. If the connection cannot be made, jump to address PETE. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|----------------------------------------------------------------------------------------------------------------|----------------------------------------| | | CONN 19399 PETE | 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 1 2 3 4 5 6 7 8 | 9 10 [11 [12 [13 [14 [15 [16 [17 [18 [19 [20]21]22]23]24]25]26 [27]28]29 [30 [31 [32 [33]34]35 [36 [37 [38 [39 | <br> 40 4 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Connect to Data Channel 3, equipment 2 and unit 4. If the connection cannot be made, have the instruction reject upon itself. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |----------------------------------------------------|------------------------------------|----------| | | CONN 3. 2. 4. * | | | <del>- </del> | 1 CIPININI | | #### The EXTERNAL FUNCTION Instruction The EXTERNAL FUNCTION instruction is an instruction that performs some type of setting or operation on a unit. This includes everything that can be done to the unit except the transmission of data. The designator $\underline{w}$ specifies the function code. For each operation there is a 12-bit function code which this instruction transmits to the unit. The function code specifying an operation for any particular unit can be found in its reference manual. The designator $\underline{x}$ specifies the data channel through which the function code is to be transmitted to the unit. The designator $\underline{n}$ specifies the Reject Jump Address if for some reason the function cannot take place. If the channel or controller or unit is not present, an interrupt condition occurs. This is called the Internal Reject Interrupt. After going through the interrupt routine, program control will then go to address $\underline{n}$ . If bit 23 is a "1" within the format of this instruction, the function code is transmitted only to the specified data channel. For these special function codes see the 3600 Computer System Reference Manual. Assuming XXXX to be the octal function code rewinding tape to load point, execute the instruction that will do so if the unit is connected to Data Channel 3. If the operation cannot be performed, jump to address ZILCH. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | EXTIF 3,XXXXB, ZILCH | | | 1 2 3 4 5 6 7 8 | 9 10111 112 113114 115 116117 118 119 20121 222 23124 25126 127 28 129 30131 132 133 134 135 13 | 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### PROBLEM: A magnetic tape unit is connected to Data Channel 2. Set the unit to BCD mode if YYYY octal is the function code. If the operation cannot be performed, jump to address NIX. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------|--------------------------------------------------| | | EXTE 2, YYYYB, NIX | | | 1 2 3 4 5 6 7 8 | 9 10[11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | 35[36]37[38]39[40]41[42]43[44]45[46]47[48]49[50] | ## PROBLEM: A magnetic tape unit is connected to Data Channel 2. Set the unit to 556 density if VVVV octal is the function code. If the operation cannot be performed, jump to address JACK. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|--------------------------------------------------------------------| | | EXTE 2, VVVVB , JACK | | | 1 2 3 4 5 6 7 8 | <br> 0 | 37 [38 39 40 4+ 42 43 44 45 46 47 48 49 50 | ## PROBLEM: A magnetic tape unit is connected to Data Channel 2. Set the unit to Interrupt On Error if TTTT octal is the function code. If the operation cannot be performed, jump to address CONT. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------|-------------------------------------------------| | | EXTE 2, TTTTB, CONT | | | 1 2 3 4 5 6 7 6 | 9 | ;<br>6 37 38 39 40;4 42 43 44 45,46 47 48,49 50 | #### The BEGIN READ Instruction The BEGIN READ instruction is an instruction that initiates transmitting of data words from the unit to memory. The data will be read from the unit which is connected to the data channel specified by $\underline{x}$ . The designator (a) m specifies an 18-bit address called the Control Word Address. At this address is pre-stored a control word for the data channel. The control word is composed of an 18-bit starting address specifying where in memory the data is to be transmitted, and a word count telling how many 48-bit words are to be transmitted. A special feature of the control word allows the programmer to "skip" records and to read variable length records without having to know how long each one is. For a more detailed explanation of these special features see the 3600 Computer System Reference Manual. If the equipment is capable of being read from, the read is initiated and program control goes to (P) + 1. The designator $\underline{n}$ specifies the Reject Jump Address if for some reason the read cannot take place. If the channel or controller or unit is not present, an interrupt condition occurs. This is called the Internal Reject Interrupt. After going through the interrupt routine, program control will then go to address $\underline{\mathbf{n}}$ . Activate a read on Data Channel 3 using control word address CWA1 from Bank 2. If the Read cannot take place, jump to address BUS. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------|----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | k 1 1 1 1 1 1 | BEGR 3, (2) CWA1, BUS | 1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1. | | 1:12:3:4:5:6:7:8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 3 | <br> | #### PROBLEM: Activate a read on Data Channel 0 using the control word from address CWA2 in the bank where CWA2 resides. If the Read cannot take place, jump to address REJ. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------| | | BEGR (#) CIWA 2, REJ | 1 | | | | 1 | | 1 1 1 2 3 4 5 6 7 8 1 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | 39 40 4: 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Activate a read on Data Channel 1 using the control word from address CWA3 in the bank where the BEGR resides. If the Read cannot take place, jump to the address of the instruction. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------------------------------------------------|----------| | | BEGR 1, (+) CWA3, | | | 1 2 3 4 5 6 7 8 | 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | <br> | ## PROBLEM: In reference to the above problem, what would the control word at address CWA3 look like if we wanted to read the first record into address FWA3 in the bank where the BEGR resides? Assume first record not over 50 words. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------------------------------|----------| | | I OTR (X) FWA3. | 5.0 | | 1 2 3 4 5 6 7 8 | 9 .01.1 12.13.14.15.5.61.71.81.9.20[21]22[23]24[25]26[27]: | <br> | #### The BEGIN WRITE Instruction The BEGIN WRITE instruction is an instruction that initiates transmitting of data words from memory to the unit. The data will be transmitted to the unit which is connected to the data channel specified by $\underline{x}$ . The designator (a) m specifies an 18-bit address called the Control Word Address. At this address is pre-stored a control word for the data channel. The control word is composed of an 18-bit starting address specifying where in memory the data is to be transmitted from, and a word count telling how many 48-bit words are to be transmitted. If the equipment is capable of being written to, the write is initiated and program control goes to (P) + 1. The designator $\underline{n}$ specifies the Reject Jump Address if for some reason the write cannot take place. If the channel or controller or unit is not present, an interrupt condition occurs. This is called the Internal Reject Interrupt. After going through the interrupt routine, program control will then go to address $\underline{n}$ . Activate a Write on Data Channel 4 using control word address CWA1 from Bank 3. If the Write cannot take place, jump to address REJ. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------| | | BEG.W 4, (3) CWA1, REJ | | | 1 2 3 4 5 6 7 8 | 9 10111 1213 14 15 16 17 18 18 18 18 20 21 22 23 24 25 26 27 28 28 28 31 32 23 34 35 | 36 37 38 39 40 4: 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Activate a Write on Data Channel 2 using the control word at address CWA2 in the bank where CWA2 resides. If the Write cannot take place, jump to address MOD. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------------|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | | BEGW 2, (\$) CWA2 MOD | | | | , (") | | | 1 2 3 3 4 3 5 6 6 7 1 | 8 9 10 111 12 13 14 15 16 17 18 19 20 21 22 23 24 25 126 27 28 29 30 31 32 33 34 35 36 | 6 3 7 38 39 40 4: 42 43 44 45 46 47 48 49 50 | #### PROBLEM: Activate a Write on Data Channel 1 using the control word at address CWA3 in the bank where the BEGW resides. If the Write cannot take place, jump to address NIX. #### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------------------------------------------|-------------------------------------------------| | | BEGW 1, LWA3, NIX | | | 1 2 3 4 5 6 7 8 | 9 10 111 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 51361371381391401411421431441451461471481491501 | #### PROBLEM: In reference to the above problem, what would the control word at address CWA3 look like if we wanted to write 20 words onto tape from address FWA3 in the bank where BEGW resides? | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------|---------------------------------------------------------------------| | | I Ø TW (*) FW A 3 , 20 | 1 1 1 5 5 1 4 5 5 6 7 4 | | 1 2 3 4 5 6 7 8 | | 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #### The COPY STATUS Instruction The COPY STATUS instruction is an instruction that probes the status of a data channel and the connected unit for various conditions. The designator $\underline{x}$ specifies the data channel through which the status is to be probed. If CW is specified by the programmer, the present Control Word will replace the contents of A with its present word count and its current word address. If CWA is specified by the programmer, the present Control Word Address will replace the contents of Q. If $\underline{b}$ is specified by the programmer, the status of the equipment will replace the contents of that index register. To interpret this status the equipment reference manual must be referenced. Program control always goes to (P) + 1 from this instruction since it is only a "probing" instruction. Probe the equipment status from Channel 2. Use Index Register 3. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------------------------------------|----------| | | COPY 2.3 | | | 1 2 3 4 5 6 7 8 | 9 10 111 12 113 114 115 116 117 118 119 20 21 122 23 24 25 26 27 128 29 30 (31 32 2 3 3 | | #### PROBLEM: Probe the control word from Channel 1. ## SOLUTION: | LOCM | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |---------------|--------------------------------------------------------------------------------------|---------------------------------------------------| | | COPY, CW 1 | | | 1 2 3 4 5 6 7 | 8 9 10 111 12 13 14 15 16 17 18 19 20 21 122 23 24 25 26 27 28 129 130 31 132 133 13 | 4 35 36 37 38 39 40 4: 42 43 44 45 46 47 48 49 50 | ## PROBLEM: Probe the control word address from Channel 0. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------| | | COPY. CWA | 1 | | 1 2 3 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 10 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 35/37/38/39/40/4. /42/43/44/45/45/47/48/49/50 | ## PROBLEM: Probe all possible status from Channel 3. Use Index Register 6 for equipment status. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------------------------------|----------------------------------------------------| | 44141 | CPPY, CW, CWA 3,6 | 1 | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 4 15 16 17 18 19 120 21 22 23 24 25 126 127 128 129 130 131 132 133 134 | 41351361371381391401411421431441451451471401401401 | ## The CLEAR CHANNEL Instruction The CLEAR CHANNEL instruction is an instruction that clears the data channel specified by $\underline{\mathbf{x}}$ . By so doing, all control is removed from the data channel. Any I/O transfer is terminated. The connection between the data channel and the unit is lost. If the programmer wishes to use a unit on data channel $\underline{x}$ after using this instruction, he must re-connect the unit with the CONNECT instruction. | $\sim$ | т. | $\sim$ | TΤ | |---------|----|--------|----| | $\cdot$ | Ľ | C | п | E X A M P L E S PROBLEM: Clear Channel 0. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------| | | CLCH | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 36137 38139 4014 42143144 45 45 17 10 40 45 | ## PROBLEM: Clear Channel 1. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------|---------------------------------------------| | | CLCH I | | | 1 2 3 4 5 6 7 8 | ]<br> | 55 36 37 38 39 40 4 :42 43,44 45 46 1: 48 c | ## PROBLEM: Clear Channel 2. ## SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------| | | $C_{1}L_{1}C_{1}H_{1}$ | : | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 16 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 3 | 34 35 36 37 38 39 40 4 :42 01 44 -65 44 -85 as as | ## PROBLEM: Clear Channel 3. | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------| | $C_{i}L_{i}C_{i}H_{i}$ | | | | 1 12 3 4 15 6 7 6 | 9 .0 11 12 3 4 15 16 17 8 19 20 21 22 23 24 25 26 27 28 29 50 31 32 33 | [34:35:18:37:138:39:40 4 42:4: 40 4. 46 47 49 4. 4 | ## The INPUT TO A Instruction The INPUT TO A instruction is an instruction that allows information to be transmitted to the A register via the typewriter or the card reader. No data channel is used by this instruction. When this instruction is encountered, the computer will wait for the typewriter or card reader (selection on console) to issue one 6-bit character (typewriter) or one column (card reader). The information is transferred to the low order bits of A and program control continues to the next instruction. #### PROBLEM: Card reader is selected. Do an Input To A. ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | T.P.A. | | | | | <del></del> | | 1 2 3 4 5 6 7 8 | 9 10 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 | ,<br>7 38 39 40 41 42 43 44 45 46 47 46 40 | ### PROBLEM: Typewriter is selected. Do an Input To A. ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|--------------------------------------------------------------------------------------------|--------------------------------------| | | I.P.A. | | | 1 2 3 4 5 6 7 8 | 9 .0[:::[:2]:3]:4]:5[:6]:7[:8]:9[:0[2:]:22[23]24[25[26]27[28]29]30[3:]32[33]34[35[36]37]38 | 13914014 [42]43;44;45]46]47;48 49;50 | #### PROBLEM: Which I/O instruction will hang up the computer? ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------| | 1 1 1 1 1 1 | I.P.A. | | | 1 [2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 4 | 014 142:43144145146147148149150 | #### PROBLEM: Which I/O instruction is only 24 bits? ### SOLUTION: | LOCN | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | | I.P.A. | | | 1 2 3 4 5 6 7 8 | 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | 13813914014-1421431441451451471401491501 | #### **NEW CONCEPTS OF GROUP 18** The concept of the I/O programming has already been introduced in Volume I, Section III with problem 19. There we included the concept with explanation of the CONN, EXTF, BEGR, and BEGW instructions. We also mentioned the control words needed with the BEGR and BEGW instructions. At this time we want to give a deeper insight into I/O operations and discuss the interdependency between I/O and interrupt. How do you set up an operation? How do you monitor it? What do you do when it's finished? In order not to confuse the discussion we will assume a 362X magnetic tape controller and a 60X tape unit for the equipment, and the principle will be similar for all other equipment. The function codes peculiar to magnetic tape are the following: | TAPE MOTION | | | | | |----------------------------|----------|-------------------------------|------|--| | Rewind | 0010 | Search E.O.F. Backward | 0014 | | | Rewind Unload | 0011 | Write E.O.F. | 0015 | | | Backspace | 0012 | Skip Bad Spot | 0016 | | | Search E.O.F. forward | 0013 | | | | | | FORMAT | | | | | Release | 0000 | Clear | 0005 | | | Binary | 0001 | 800 BPI Density | 0006 | | | BCD | 0002 | Clear Reverse Read | 0040 | | | 556 BPI Density | 0003 | Set Reverse Read | 0041 | | | 200 BPI Density | 0004 | | | | | | INTERRUI | PT | | | | Interrupt On Ready | 0020 | Release Interrupt On | 0023 | | | And Not Busy | | End of Operation | | | | Release Interrupt On Ready | 0021 | Interrupt on Abnormal | 0024 | | | And Not Busy | | End of Operation | | | | Interrupt On End | 0022 | Release Interrupt on Abnormal | 0025 | | | Of Operation | | End of Operation | | | These function codes are 12 bit codes generated by the central processor when the EXTF instruction is executed. All are in octal form. None of these codes transmit data. The codes have the following meanings: #### TAPE MOTION | 1. | Rewind (0010) - | This code rewinds tape at high speed to load point. | |----|------------------------|--------------------------------------------------------| | | | It has no effect if the tape is already at load point. | | 2. | Rewind Unload (0011) - | This code rewinds tape at high speed to load point. | | | | It then rewinds tape slowly until all of the tape is | | | | on the supply reel. The tape must be manually re- | | | | loaded in order for any further operations to occur | | | | on it. | | 3. | Backspace (0012) - | This code backspaces the tape one record or until | | | | load point is detected. If Reverse Read (607 only) | is also selected, the tape will forward space one 4. Search E.O.F. Forward(0013)-This code advances tape until the next file mark is detected. record. - 5. Search E.O.F. Backward(0014)- This code backspaces tape until a file mark is detected. - 6. Write E.O.F. (0015) -This code advances the tape approximately 6 inches and writes a BCD $17_8$ . This does not affect the recording mode. - 7. Skip Bad Spot (0016) -This code erases approximately 6 inches of tape. # FORMAT | 1. | Release (0000) - | This code logically disconnects the connected unit and removes the reserve so that other data channels through a multi-channel controller may have access to it. | |----|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2. | Binary (0001) - | This code causes all data read or written to be done so in binary notation. | | 3. | BCD (0002) - | This code causes all data read or written to be done so in BCD notation. | | 4. | 556BPI Density (0003) - | This code causes all data read or written to be done so at 556 frames per inch. | | 5. | 200BPI Density (0004) - | This code causes all data read or written to be done so at 200 frames per inch. | | 6. | Clear (0005) - | This code clears all reservations made through the data channel and logically disconnects the connected unit. | | 7. | 800BPI Density (0006) - | This code causes all data read or written to be done so at 800 frames per inch. This is possible on the 607 only. | | 8. | Clear Reverse Read (0040) - | This code clears the condition set by the Set Reverse Read code. | | 9. | Set Reverse Read (0041) - | This code set up the condition that any tape read will occur in the reverse direction. | #### INTERRUPT Interrupt on Read -And Not Busy (0020) This code causes the controller to send an interrupt signal to the processor when the tape unit is in a Ready and Not Busy condition (all tape motion has ceased). This signal is cleared by a 0021 code. Release Interrupt on Ready -And Not Busy (0021) This code clears an Interrupt on Ready and Not Busy selection and signal if it is up. 3. Interrupt on End-Of Operation (0022) This code causes the controller to send the interrupt signal when an End of Record is sensed. 4. Release Interrupt on End - Of Operation (0023) This code clears the Interrupt on End of Operation selection and signal if it is up. Interrupt on Abnormal -End of Operation (0024) This code causes the controller to send an interrupt to the processor after an abnormal condition occurs For magnetic tape these conditions are: - a. File Mark - b. Load Point - c. Vertical Parity Error - d. Longitudinal Parity Error - e. Lost Data - f. Parity Error During Skip Bad Spot - g. Connected Tape Unit Becoming Not Ready - 6. Release Interrupt On Abnormal End of Operation (0025) This code clears the Interrupt on Abnormal $\operatorname{End}$ of Operation selection and signal if it is up. The INTERRUPT function codes are common to all controllers with only the "abnormal conditions" listed being different. All codes listed are used to position tape and set operating mode before actual transfer of data takes place. The condition of the unit can be monitored at any time through the use of the COPY (status) instruction. The unit status is received in the lowest 12 bits of an index register, each bit representing a condition. A "1" bit means the condition is present as follows: | STATUS REPLIES | | | | | | | |----------------|------------------|--------|---------------------------|--|--|--| | Bit 0 | Ready | Bit 6 | Density (556 or 200BPI) | | | | | Bit 1 | Channel, Control | Bit 7 | Density (800BPI) | | | | | | or Unit Busy | | | | | | | Bit 2 | Write Enable | Bit 8 | Lost Data | | | | | Bit 3 | File Mark | Bit 9 | Longitudinal Parity Error | | | | | Bit 4 | Load Point | Bit 10 | Vertical Parity Error | | | | | Bit 5 | End Of Tape | Bit 11 | Reserve Reject | | | | The status can be checked by the "Bit Sensing" instruction (NBJP or ZBJP). This instruction can examine any bit in any operational register. On the COPY instruction the 12 bits are received in the lower portion of the index register. The uppermost three bits of the register will contain channel status as follows: Bit 14 - "1", transmission parity error has occurred. This is between memory and channel and between channel and controller only. Bit 13 - "1", write operation is in progress. Bit 12 - "1", read operation is in progress. ### Problem 18: Write a subprogram that will do the following: - 1. Clear channel #0. - 2. Connect equipment #3, unit #2 (mag. tape) to channel #0. - 3. Set format to BCD, density to 556. - 4. Rewind to load point. - 5. Set up Interrupt On Abnormal End of Operation. - 6. Transmit the 1st record to address REC1. - 7. Transmit the 3rd record to address REC3. - 8. When finished, exit. Assume the records are each less than 100 words. #### Flowchart: Problem 18 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIE | RS ADDRESS FIELD | COMMENTS | |------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------|---------------------------| | 1 [2 [2 [4 [5 [4 [7 ]8 | g 186[17][17][17][15][14][19][16][17][18][19 | <br> 180 23 27 29 24 25 30 27 78 26 30 31 32 53 34 25 36 27 39 29 40 | <br> | | | IDENT | READINT | | | | ENTRY | READINT | | | REC/ | BS.S. | 10.0 | | | REC3 | BSS | 100 | | | CWAI | IOTR,C | REC1, 100 | | | | | 0,/100 | <u></u> | | | IPTR | REC3, 1,00 | | | READINT | BSS | 1/ | <u> </u> | | | CLCH | 9 | !<br><u> </u> | | | CON | 0,3,2,* | | | | EXTE | 0,2,* | SET FORMAT TO BCD | | | EXTE | P,3,* | SET DENSITY TO SSG | | | EXTF | 0,108,* | REWIND | | | EXIF | 0,248,* | ABNORMAL END OF OPERATION | | | BEGR | 0, CWA1, * | TRANSFER DATA | | | COPY | 0,1, | STATUS TO BI | | | WBJP | B1, 12,*-1 | LOOP IF STILL READING | | | And Additional control from the control | READINT | FINISHED | | and an artist American | END | | | ### Student Problem 18A: Write a subprogram that will do the following: - 1. Clear channel #2. - 2. Correct equipment #4, unit #1 (mag. tape) to channel #2. - 3. Set format to BIN, density to 200. - 4. Rewind to load point. - 5. Set up Interrupt On Abnormal End of Operation. - 6. Write 20 words starting at CARDBUFF as one record. - 7. When finished, exit. #### Flowchart: # Problem 18A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------|---------------------------------------------------| | 1 2 2 4 2 4 7 4 | • 10,11,12,13,14;15,14,17,14;16 | 20 21 17 23 24 25 24 27 28 26 36 31 32 33 34 35 36 37 38 37 38 | <br> | | | 4 | | | | <u> </u> | | | | | | <del> </del> | | | | | | | | | | | | <u></u> | | | | | <del> </del> | | | | | 1 | | | + | | <u> </u> | | | + | <u></u> | | | | | <del> </del> | | | | | | | | | | | | | | | | | | | | !<br><u> </u> | l<br>L., | | | | | | | | | | | | | | | | | | | | <u> </u> | | | <u> </u> | <u></u> | <u> </u> | # GROUP 19 LOCAL STORAGE ALLOCATION #### GROUP 19 #### LOCAL STORAGE ALLOCATION | 1. | Block Storage Reservation (Starting) | BSS | |----|------------------------------------------|------| | 2. | Block Storage Reservation (Ending) | BES | | 3. | Octal Data Initialization | OCT | | 4. | Decimal Data Initialization | DEC | | 5. | Double Precision Data Initialization | DECD | | 6. | Binary-Coded-Decimal Data Initialization | BCD | | 7. | Type Character Initialization | TYPE | | 8. | Variable Field Data Initialization | VFD | | 9. | Literals | = MV | | | | = S | The first two instructions allow the programmer to declare a block of one or more words to be reserved before execution of the program. During the execution of the program, the programmer generates words and stores them in this area. The next three instructions allow the programmer to prestore data before execution of the program. Constants are usually prestored with one of these instructions. The BCD and TYPE statements allow the programmer to prestore messages that are to be output sometime during the execution of the program. The VFD statement prestores data in variable bytes. The "string" of data can be of different modes. The last item, "literals", is not a statement but a different method used to allocate storage words. Since this is a new concept, more is said on it further in this group. #### The BSS Instruction ### FORM: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|------------------------------------------------------------------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------| | 112121412141714 | • 10 11 17 L 12 14 15 16 17 12 19 20 21 177 17 | 1124 (25 124 127 128 129 126 126 127 137 133 124 125 124 137 126 129 1 | # ] 41 42 45 44 45 44 45 44 45 55 55 55 55 55 55 55 55 55 55 55 65 65 65 65 65 65 75 7 | | l | BISS | 1 | ( | | | | | | This instruction reserves a block of consecutive 48-bit machine words. The value of the expression in the address field determines the number of words to be reserved. A location symbol is optional. If present, it is assigned to the first word reserved. In this case the programmer would use forward addressing. The area reserved will not be zeroed out prior to execution. If the programmer so desires, he must do it within his program. ### The BES Instruction ### FORM: | LOCATION | Г | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-------------------------------|---|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|----------| | 1 1 2 1 3 1 4 1 5 1 4 1 7 1 4 | , | 10 13 13° 13° 14 15° 14 17° 13° 19° | 20 [21 [77 ] 27 24 25 24 27 27 28 29 30 31 37 25 24 27 28 27 28 27 40 | <br> | | l | | BES | <b>,</b> | <u> </u> | | | Γ | | | ;<br> | This instruction is the same as the BSS instruction, except that the symbol in the location field, if any, is assigned to the last word of the block. In this case the programmer would use backward addressing. #### The OCT Instruction #### FOR M: | LOCATION | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|----|--------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|----------| | 3 1 2 1 3 1 4 1 5 1 4 1 7 1 6 | ļ. | 19 33 122 123 34 125 144 127 328 128 129 129 129 129 129 129 129 129 129 | 1 37 1 34 1 25 1 36 1 37 1 28 1 27 1 36 1 31 1 32 1 33 1 34 1 35 1 34 1 37 1 38 1 39 1 4 | ]<br>] | | l | | 100 | C2, C3, , | | | 1 1 1 1 1 1 1 | Ľ | | | | This instruction is used to prestore octal constants. Constants are declared in the address field separated by commas. Each constant requires one 48-bit word. The constants can be 1 to 16 octal digits, signed or unsigned. If a constant is less than 16 digits, it will be right justified in the word with the sign extended. The character $\underline{B}$ is not allowed. The assembler automatically assumes octal. A location symbol is optional. If present, it is assigned to the first word. The following are valid examples of an OCT instruction: | CØNX | ФСТ | 1,456,-7,0,-0 | |------------|--------|-------------------| | | | | | (CØNX) | = 0-> | 01 | | (CONX + 1) | = 0->0 | <b>)4</b> 56 | | (CØNX +2) | = 7 | <b>&gt;</b> 70 | | (CØNX +3) | = 0 | <b>→</b> 0 | | (CONX + 4) | = 7- | <del>&gt;</del> 7 | #### The DEC Instruction #### FOR M: | LOCATION | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------|---|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-------------------------------------------------------------| | 1 12 13 14 8 14 17 14 | , | 100 131 132 133 144 135 144 137 145 145 230 231 232 23 | [24 ; 25 ; 36 ; 27 ; 76 ; 29 ; 36 ; 31 ; 32 ; 33 ; 24 ; 25 ; 36 ; 37 ; 38 ; 39 ; | # 4 42 43 44 45 46 45 46 46 46 56 5 | | $\ell$ | | DEC C1.C | 2, 63, | | | | | | | | This instruction is used to prestore decimal constants. Constants are declared in the address field separated by commas. Each constant requires one 48-bit word. Constants are prestored in two different forms with this instruction: fixed point integer and floating point. If no decimal point is found in the constant, it is stored in fixed point integer form. If a decimal point is found in the constant, it is stored in floating point form. Care must be taken by the programmer that the forms are not mixed when using fixed point arithmetic instructions or floating point arithmetic instructions. A location symbol is optional. If present, it is assigned to the first word. The following constant specifications are legal: PERCNT DEC 5, 0, -8 (PERCNT) = 0 $$\longrightarrow$$ 005 (PERCNT + 1) = 0 $\longrightarrow$ 000 (PERCNT + 2) = 7 $\longrightarrow$ 767 PARAM DEC 10., 0., -. 5 (PARAM) = 200450 $\longrightarrow$ 0 (PARAM + 1) = 0 $\longrightarrow$ 0 (PARAM + 2) = 577737 $\longrightarrow$ 7 Also legal as a constant specification is the form; fDdBb This specification allows constants to be formed in scientific notation as; ${}_{f^{\star}}\ 10^{\mbox{d}}\!\cdot 2^{\mbox{b}}$ The $\underline{f}$ specification determines the format as fixed or floating point. The $\underline{d}$ and $\underline{b}$ exponents may be signed or unsigned integers. The following represent valid address field constants: | | Specification | Value | |----|---------------|---------------------------| | 1. | 85D4 | 850,000; fixed point | | 2. | -27D3B2 | -108,000; fixed point | | 3. | 7.6D-6 | . 0000076; floating point | #### The DECD Instruction #### FORM: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|-------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------| | 1,2,2,4,5,4,7,4 | # 100 [17 [17 [18 ] 14 [15 ] 16 [17 [18 ] 19 ] 20 [21 [22 ] | 27 134 23 534 127 24 128 139 130 137 132 133 134 125 134 137 134 135 | [44] 41 [42] 45] 44[47] 44[47] 44[47] 55 [51 [52] 55 [54 [55] 57] 58 [55 [66] 41] 42 [42 [45] 45 [45] 45 [47] 56 [47] 57 [47] 77 | | / | DECD C1 | C2, C3, 000 0 1 1 1 1 | 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1 | | | | 7.000 | <del>- - - - - - - - - - </del> | | $\mathbf{H}$ | 1 | <del></del> | <u> </u> | This instruction converts double precision floating point constants to binary and stores them in consecutive pairs of machine words. The rules are the same as for the DEC instruction, except that more digits can be specified for precision and accuracy. Up to 25 digits may be specified. The following are valid representations of constants: CØNX DECD - 01364295634574321697, 3. 1415963214631794 CØNX and CØNX + 1 contain the first operand in floating point format. CONX + 2 and CONX + 3 contain the second operand in floating point format. These operands are operated on with any of the following instructions which automatically reference two memory words: - 1. DLDA - 2. DSTA - 3. DFAD - 4. DFSB - 5. DFMU - 6. DFDV #### The BCD Instruction #### FORM: | LOCATION | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|---|----------------------|----------------|----------| | 1 2 2 4 3 6 7 3 | , | <br> | [21 | <br> | | l | | <b>~</b> . | 18n characters | • | | | | | ,<br> | <u> </u> | This instruction stores internal BCD characters in consecutive machine words, 8 characters per word. The address field consists of a word count, n, followed by a comma and up to 8 characters following. The word count determines the number of characters scanned on the card. The characters may be any legal BCD characters. This includes blanks, periods, commas, etc. The address field is terminated by the 8n characters being satisfied. Any more characters, to column 73, are treated as remarks. A location symbol is optional. If present, it is assigned to the first word. Here is an example of how the BCD characters are prestored. MESSAGE BCD 2, NØ ERRØRS FØUND (MESSAGE) = NØ ERRØR(MESSAGE + 1) = S FØUND #### The TYPE Instruction #### FORM: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------|---------------------------------------| | 1 2 2 4 5 4 7 8 | ៖ សុហស្រប្រាប្រសួសស្រប្រាប្រាប្រាប្រ | 21 <u>:77 27 24 25 26 27 28 29 36 31 33 33 35 36 37 36 37 36 37 4</u> | <br> | | l | I-1 1 | Sin Chanacters | • • • • • • • • • • • • • • • • • • • | | | | , , , , , , , , , , , , , , , , , , , , | !<br> | This instruction is very much like the BCD instruction except that the characters are in typewriter code. For special settings on the typewriter, the following code is used: | Specification | Meaning | |---------------|---------------------| | *R | Carriage Return | | $*\Pi$ | Shift to Upper Case | | *L | Shift to Lower Case | | *B | Backspace | | *T | Tab | | *X | t | | *A | 1 | | *S | ; | Even though each specification represents two columns on the card, it represents and counts as only one typewriter character. Here is an example of pre-storing a typewriter message. | MESSAGE | $\mathbf{TYPE}$ | 3, * | RREMOVE TAPE REEL XX | |------------|-----------------|------|----------------------| | (MESSAGE) | | = | *RREMOVE | | (MESSAGE + | 1) | = | TAPE REE | | (MESSAGE + | 2) | = | L XX | #### The VFD Instruction #### FOR M: | LOCATION | OPERATION, MODIFIERS ADDRESS | FIELD COMMENTS | |-----------------|--------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 112121413141214 | 9 10 11 17 13 14 15 16 17 16 19 20 21 27 29 20 20 27 29 20 27 29 29 20 | [23,25]M[28,124,127]M[27,48]41]41]41]41]41[41]41[41]41[41,28]31]39[31]M[31,31]39[31]41]41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41]41[41[41]41[41]41[41]41[41]41[41]41[ | | L | VFD mn/v, mn/v, | 1 | | | | | This instruction allows the programmer to pre-store variable types of data. The data can form a continuous string and can be of different modes. The instruction can convert octal and decimal constants, hollerith characters, typewriter characters and arithmetic expressions. The address field consists of one or more subfields separated by commas. Each subfield is in the form mn/v, where m specifies mode, n specifies number of bits, and v specifies value. The address field is terminated by the first blank which is not a part of a hollerith or typewriter field. A location symbol, if present, is assigned to the first word. Five modes are allowed: On/v Octal constant - Same rules as on OCT instruction except that n may range from 1-48. Hn/v Hollerith character code - Same rules as on BCD instruction except n must be a multiple of 6 since n represents characters instead of words. Tn/v Typewriter character code - Same rules as on TYPE instruction except <u>n</u> must be a multiple of 6 since <u>n</u> represents characters instead of words Bn/v Bank term - the <u>n</u> term may be omitted as it is always assumed 3. The <u>v</u> term, when stored, must coincide with a bank designated position in a machine word. An/v Arithmetic expression of decimal constant - represents a decimal fixed point constant or a relocatable expression if n = 15. An example of how a "string" of data can be formed is shown here: STRING VFD O24/-41, A24/32, T24/ABCD, H24WXYZ (STRING) $= 7 \longrightarrow 7360 \longrightarrow 040$ (STRING +1) ABCDWXYZ #### LITERALS #### FORM: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 1 2 2 4 2 4 7 8 | • Wittist 12 13 14 15 16 17 16 19 20 21 | 1 (72 27 24 25 24 27 28 27 18 27 18 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 27 28 | <br> | | | Instra. | _ | <u> </u><br> | | | = 9 | BNAME | <u>.</u><br>1 | | | ]=,p | SNAME | <u> </u> | | 4 1 1 1 2 1 1 | | | [<br> | Specifying literals in a subprogram gives the programmer an easy, fast, and efficient method of pre-storing data and reserving a block of memory. Consider the following set of instructions: | LDA | CØN1 | |-----|------| | MUI | CØN2 | | STA | SAVE | If the program multiplies two constants, they must be specified somewhere, probably with a DEC card. Also, if the program stores the result, the address must be reserved, probably with a BSS card. If the constants are known, there is an easier method to perform the operation; using literals. By doing so, the programmer could have coded as follows: | LDA | <b>≘</b> D1564318 | |-----|-------------------| | ADD | =D-16741 | | STA | =SSAVE | The execution time for either method is the same. But the second method needs no pseudo instructions to pre-store the data or reserve the area. The Compass assembler automatically does so when the equal sign is scanned and the value is read. A literal usually replaces the <u>m</u> subfield of an instruction and has the form: - 1. = MV - 2. = SNAME - 3. =DSNAME - 1. Literal Form: = MV For this literal, $M = \underline{\text{mode}}$ and $V = \underline{\text{value}}$ . The mode can be any of the following: | D Decimal constant | The value can be any of those | |--------------------|-----------------------------------| | | allowable on the DEC instruction. | | O Octal constant The | value ca | an be | any of | those | allow- | |----------------------|----------|-------|--------|-------|--------| |----------------------|----------|-------|--------|-------|--------| With the preceding literals the following instructions could be coded: The programmer must make sure that the instruction and arithmetic format agree. 2. Literal Form: =SNAME For this literal S <u>Storage address</u>. The "S" must be specified and is followed by the name. When the name is scanned by the assembler, a memory word is automatically reserved. This literal is closely related to the BSS instruction. With this literal the programmer can code; STA =SHOLD Here he is storing A at address HOLD, which does not have to be declared in the location field. The assembler generates its own address. #### 3. Literal Form: =DSNAME For this literal DS ≡ double precision storage address. The "DS" must be specified and is followed by the name. Two words are reserved at addresses: NAME and NAME + 1. This literal is usually used with double precision floating point arithmetic. #### NEW CONCEPTS OF GROUP 19 The local storage allocation pseudo instructions are not machine instructions as we had presented in the last 18 groups (except for IDENT, ENTRY, BSS, OCT, DEC, and END instructions). Since these are not machine instructions, they normally go before the beginning, or after the end of the executable part of the program. The only time they could be placed within the executable part of the program is if the programmer jumps over the area, or instructions are placed in the area before the area is executed. A block area reserved by the BSS instruction can make use of the ISK instruction to process or generate consecutive data. A block area reserved by the BES instruction can make use of the IJP instruction. Literals usually should replace instructions having an $\underline{m}$ subfield. There is a difference between the instructions; - 1. LDA =D691534 - 2. ENA =D691534 The first one loads A with the decimal integer 691534. The second one enters the assembler generated address into A with sign extended. This, in most cases, represents an undefined quantity. ### Problem 19: Use literals to solve the problem to solve $Z = \frac{5.8X - 6.7Y}{-4.9}$ if X and Y are given in floating point. Problem 19 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIE | RS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------|---------------------------------------------------| | 1 2 3 4 5 4 7 8 | 9 10 1 11 12 13 14 1 15 1 14 1 17 1 18 1 19 | 20 21 27 27 24 25 26 27 26 29 30 31 32 35 36 25 26 37 38 37 48 | <br> | | <u>i</u> | | EVAL | | | | ENTRY | EVAL | | | 7 | BSS | 1 | | | EVAL | BS.5. | 12 | | | | LDA | <u> </u> | | | | FMU | = D6.7 | | | | STA | -SHOLD | | | | LDA | X | | | | | -05.8 | | | | FSB | | 5.8x-6.77 | | | FDV | =D-4.9 | <u></u> | | | | <u>Z</u> | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | SLJ | EVAL | <u> </u> | | | END | <u> </u> | <del> </del> | Somewhere within this subprogram would also be included the symbols X and Y in the location field with a declaration of the pre-stored data or area reserved. ### Student Problem 19A: Using literals write a subprogram to evaluate $Q = \frac{-4.8(3R + 7.1S)}{8.2S - 71.6T}$ if R, S, and T are given in floating point. Flowchart: # Problem 19A could be solved by coding in the following manner: | <del></del> | | |-------------|---------------------------------------------------| | | <u> </u> | | | <del> </del> | | | <del></del> | | | <del> </del> | | <del></del> | | | | <del></del> | | | | | | <del> </del> | | | <u> </u> | | | | | | | ## GROUP 20 SUBPROGRAM LINKAGE ### GROUP 20 #### SUBPROGRAM LINKAGE Entry External EXT These are the instructions that allow communication between subprograms. Neither of them generates words or uses up memory core. When the symbols are extracted, they are entered into a symbol table for cross-referencing at load time. ### The ENTRY Instruction ### FOR M: | LOCATION | Γ | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |------------------|----|----------------------|----------------------------------------------------------------------------------------|--------------------------------------------| | 1 12:3:413:4:7:4 | Ι, | <br> | 7 34 : 25 : 36 77 : 78 27 30 31 32 : 35 34 35 : 36 37 : 78 : 57 40 | <br> | | | T | ENTRY | | ,<br>1 , , , , , , , , , , , , , , , , , , | | | | | | | This instruction declares alphanumeric symbols within the subprogram as entry points which may be referenced by other subprograms. An entry point must be defined in the location field in the same subprogram that it is declared. Entry point symbols must be unique. ### The EXT Instruction ### FORM: | LOCATION | I | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |------------------------|---|----------------------|---------------|----------------------------------------------------------------------------------------------------------| | 1 12 12 14 14 14 17 14 | | <br> | [2] | 41:42 43 44 45 64 47 44 49 56 51 52 55 54 55 56 57 56 55 40 61 42 42 64 65 44 65 46 67 66 70 70 70 70 70 | | | Ι | EXT | <u> </u> | | | 1 1 1 1 1 1 1 | I | | | | This instruction declares symbols that are external to the subprogram in which the EXT instruction occurs. Symbols are declared like they are on the ENTRY instruction. At load time external symbols are assigned the value corresponding to the symbol in another subprogram. For every external symbol, there must be a corresponding entry point. The converse is not true. #### NEW CONCEPTS OF GROUP 20 The concepts given for this group may represent the most important information contained in this manual. Not only is the communication between subprograms discussed, but also communication between subprograms in a multi-bank system. This is especially important for the 3600/3800 systems programmers. The discussion is divided into two parts: - 1. A discussion of subprogram communication in a one-bank system. This applies to the 3400/3600/3800 systems. - 2. A discussion of subprogram communication in a multi-bank system. This applies to the 3600/3800 systems. - 1. Subprogram Communication in a One-Bank System We already know that a subprogram consists of the instructions from IDENT through END. We have solved problems using this basic subprogram form. Now let's discuss subprograms further and introduce new ideas and definitions as we go along. We speak of a subprogram as being a <u>closed</u> routine. By this we mean that all symbols are <u>local</u> to the routine. This means that, within a subprogram, any symbol in the address field must be declared in the location field, unless the symbol is declared external to the subprogram or in Common (discussed later). The symbol then becomes global (opposite of local). Subprograms can be assembled together as such: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 2 3 4 3 4 7 8 | • 10-17-11-11-11-11-11-11-11-11-11-11-11-11- | 27 27 24 25 24 27 28 27 28 3 3 3.5 24 35 26 37 38 27 48 | <br> 41 42 45 46 45 46 47 46 46 56 51 52 53 56 55 56 57 56 57 56 57 56 57 56 57 56 57 56 57 57 | | | TDENT A | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | ENTRY | <u> </u> | | | | 1 | <u> </u> | | | | <u> </u> | | | | 11111111 | 1°-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1- | | | | | END A | | <u> </u> | | | IDENT B<br>ENTRY B | 1 1 4 4 1 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 | <u> </u> | | | ENTRY | | <u> </u> | | | | | <u> </u> | | | | حاصل کا خان نے خوان کی مان کی ان کا ان | <u> </u> | | | END | | | | | IOENT C | | | | | ENTRY | | | | | | | 1<br>1 <u></u> | | | • | | | | | <u> </u> | | | | | END | <u></u> | | Each subprogram is assembled as a separate independent subprogram. The first subprogram is usually referred to as the <u>main subprogram</u> and the others as <u>sub-subprograms</u>. If a subprogram is to be entered for execution, an entry point into the subprogram must be given. This is why you see at least one entry point for each subprogram. How do we know which subprogram program control is <u>initially</u> going to enter? This is specified in the address field of <u>one</u> of the END instructions. This symbol is an address which is declared an entry point into one of the subprograms. This is called the "transfer address", the address to which program control will initially transfer to after the subprograms have been loaded and are ready to run. Note in the example above how subprogram A will initially be entered. Program control actually starts at that address +1. At the address is stored a 48-bit instruction that, when executed, will return program control to the monitor. This is why, at the end of a subprogram, an SLJ is made to the entry point, which executes the stored instruction. Now how does the programmer transfer control from one subprogram to another? He does this by declaring a symbol external (EXT) and jumping to it. Of course, the symbol must be declared an entry point (ENTRY) in the subprogram jumped to. For a one-bank system the subprograms might look like this: | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------| | 1 2 3 4 5 4 7 8 | 9 10 (13 ) 17 (13 ) 74 (15 ; 16 ; 17 ) 18 ; 19 | 20 23 27 29 24 23 24 27 28 27 28 47 37 23 24 37 34 27 37 38 | 0 - 42 43 44 45 46 47 48 48 51 52 53 54 55 56 57 56 55 56 57 57 | | | LOENT | <u> A</u> | | | | | | | | | <u> </u> | | | | | | | | | | EXT | <u> 34.8</u> | <u> </u> | | | | Sub. | | | | <del> </del> | <u> </u> | | | | • | | <u> </u> | | 11414 | END | <del> </del> | | | | | SuB | | | | | SuB | | | SuB | | ** | | | | • | | | | | <u> </u> | <u> </u> | | | | <u> </u> | <u> </u> | | | لنلنالنا | | SuB | | | | END | <u> </u> | | Here, the second subprogram is treated as a subroutine to the main subprogram. Notice how the symbol SUB is declared external in the first subprogram and an entry point in the second subprogram. When the "return" is made from the second subprogram to the first, it is not necessary to declare an external symbol or entry point. The return is taken care of automatically by the hardware. A SLJ is made to SUB which will return control to the first subprogram, to the point from which it left off. So we might say that EXT-ENTRY declarations are necessary going in the forward direction but not when returning. This concept is especially important when nesting subroutines. EXT-ENTRY instructions can also be used to reference data outside of a subprogram. Consider the following: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |------------------------|--------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------| | 1 12 12 14 14 14 17 14 | 9 10 <sub>1</sub> 73 <u>117 18 18 18 17 18 19 20 2</u> 1 | 0 : 22 : 23 : 24 : 25 : 26 : 27 : 28 : 25 : 36 : 31 : 32 : 33 : 34 : 35 : 34 : 37 : 38 : 39 : 40 | <br> 41 42 43 44 45 46 47 48 49 50 31 52 33 54 59 56 57 58 39 40 41 62 48 56 45 46 45 46 49 70 71 72 | | | IDENT A | . 1 . 1 . 1 . 1 . 1 . 1 . 1 . 1 . 1 . 1 | | | | <u> </u> | <u> </u> | | | | <del> </del> | | | | | <del> </del> | | | | | | 2W1, X | | | | | 6N2 | | | | | pN1+1 | | | | STAX | | | | | <del>- </del> | <u></u> | | | | 1 | | <u> </u> | | | ENO | | | | | TOENT B | <u> </u> | <u> </u> | | | | CON1,X | | | GON2 | | 6.8,3.14159 | <u> </u> | | <i>X</i> | BSS | <u> </u> | | | | <del> • • • • • • • • • • • • • • • • • • •</del> | | | | | 1. | <u> </u> | | | | END | <u> </u> | | Note how the data is read and stored outside the subprogram. In fact a whole table can be read or generated outside a subprogram by means of the EXT-ENTRY instruction and an index counter. By using the EXT-ENTRY instructions we make the symbol global instead of local to the subprogram. #### 2. Subprogram Communication in a Multi-Bank System Assuming we know a little about subprograms existing in one bank, we now discuss subprograms existing in more than one bank (3600/3800 systems only). Here we have to be careful, because we have two bank registers to consider, one for instructions and one for operands, and it becomes easy to reference the right address but the wrong bank. Subprograms in a multi-bank system may be interspersed through memory; a few in bank 0, a few in bank 1, etc. However, it is important to note that each subprogram must be wholly contained in one bank, i.e., one part may not be in one bank and the other part in another bank. Unless the programmer knows for sure that subprograms are loaded into the same bank, he normally makes use of the bank designators given in the Compass instruction formats. when transferring control from one subprogram to another or referencing data in another subprogram. Let's assume a simple example. Suppose subprogram A is in bank 1 and subprogram B is in bank 2. Control can be transferred from subprogram A to subprogram B as follows: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------| | 212121415141714 | · minimimimimimimimimimimimimimimimimimim | 23 <u>(27 27 24 25 24 27 78 28 28 31 33 33 34 35 36 37 38 37 48</u> | 41:47 [40] 44 [45 [46 [47] 44; 47; 48; 51 [57] 53 [54 [57] 54 [57] 55 [57] 46 [47] 45 [46 [47] 46 [47] 47 [77] 77 [77] | | | IDENT A | | IN BANK 2 | | | <u> </u> | <u> </u> | | | | <del> • </del> | <u> </u> | | | | EXT | <del></del> | | | | | | | | | DKI S | 2) B | | | <del></del> | | | | | | | <u> </u> | | | | END | | | | | IDENT B | | IN BANK 2 | | | ENTRY B | | | | В.,,,,, | BSS 1, 2 | | | | | | | | | | <u> </u> | | | | +11111 | | | | | | SLT B | <del></del> | | | | END | | <u></u> | In this case the symbol is again declared external. In order to transfer control across banks a bank jump instruction is necessary, and in this case a BRTJ instruction is used. The second subprogram is then treated as a subroutine. It will process operands in bank 2. Now let's suppose the same problem as above, except that in subprogram A there exists a table of 100 locations starting at TAB. When the return jump is made to subprogram B, it is to process the data beginning at TAB in subprogram A. Here is an example of what is needed. | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-------------------------------|------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------| | 1 2 : 3 4 3 : 4 7 4 | <ul> <li>ល់ប្រាក់សិរីលេខិត្តទំនិងកែនៈ ដែរ</li> </ul> | [80 21 177 25 24 25 24 27 26 26 26 31 32 33 24 25 26 37 36 37 38 37 | <br> | | | IDENT. | A | IN BANK IL | | | | A, TAB | | | TAB | 8.5.5 | 100 | | | A | 85 <u>5</u> | 1 | | | | | | | | | <u> • • • • • • • • • • • • • • • • • • •</u> | | | | | <u> </u> | | 1 | | | | B | 1 | | | BRTJ | (2)8 | <u> </u> | | | <u> </u> | | 1 | | | <u> </u> | | 111111111111111111111111111111111111111 | | | | <u> </u> | <u> </u> | | 1111111 | END | <u> </u> | IN BANK 2 | | | TOENT | <u> 8</u> | ! | | | | TAB | | | $\boldsymbol{\beta}$ | B.5.5 | !/ | | | Pillin | | TAB | | | | | | | | | <b> </b> | | | | | <b>.</b> | | | | | 547 | <b>B</b> | | | | ENO | | | | | | 1 | <u> </u><br><u> </u> | | | | | <u> </u><br> | | | | | <u> </u><br><u> </u> | | | | | 1 | Any time a symbol is referenced outside a subprogram, it must be defined as an external symbol and elsewhere as an entry point. When the subroutine is entered, the Operand Bank register is 1 from the BRTJ. For this reason no bank term is necessary on the LDA instruction (LDA is added just as an illustration). It will load the first word at TAB. If indexing was used in the subroutine, the complete table at TAB could be processed. The previous two examples dealt with subprograms that were each in a given bank. We could use numeric bank designators so that we made sure that we referenced not only the right address, but also the right bank. But what if two subprograms exist in two different banks and it is not known which bank they reside in? Can there be communication between the two subprograms? Yes, there can be, and it requires some more definitions of bank designators. The bank designator may be one of the following symbols: ### 1. Bank Designator ### Meaning \$ The bank that the associated symbol resides in. Example: LDA (\$) NUM Meaning: Load A from address NUM from the bank in which NUM resides. NUM would be declared an external symbol, and in its subprogram, an entry point. This instruction actually changes the Operand Bank control to the bank of NUM and will remain there until it is explicitly changed again. #### 2. Bank Designator #### Meaning \* The bank that the instruction using this symbol resides in. In other words, the bank of the associated subprogram. This instruction actually changes the Operand Bank control to the bank of the present subprogram and remains until it is explicitly changed again. Let's assume that in subprogram A we wish to form Z= 3.5X-6.7, but that 3.5 is in subprogram A and 6.7 is in subprogram B, both in floating point form. Here's how it could be done. | LOCATION | OPERATION, MODIFIE | RS ADDRESS FIELD | COMMENTS | |-------------------------------|-------------------------------------------|-------------------------------------------------|-----------------------------------------------| | 1 2 2 4 3 4 7 8 | 9 NO 1 10 102 105 134 135 136 137 138 109 | <br> | <br> -<br> | | | IDENT | A | IN ONE BANK | | | ENTRY | A. J. J. L. | <u> </u> | | | | CAN2 | <u> </u> | | CONI | | 3.5. | <u> </u> | | X | | 700.14 | | | 2 | BSS | <u> </u> | | | $A \cdots \cdots$ | BSS | 12 | | | | LDA | <u>X</u> | | | | | CON1 | Lute u To Ald Turo Call | | | FSB<br>STA | (*) COU2<br>(*)Z | SWITCH TO ANOTHER BANK<br>RETURN TO THIS BANK | | | | (*). <del>*</del> | KYJUKN ID IHID BAUK | | | END | <u>1<i>A</i></u> | <u> </u> | | | IDENT | <br> R | IN ANOTHER BANK | | | | B, COND | TO COUNT BER DAMA | | 1/2 | DEC | V . 7 | <del></del> | | 4/4 | | • • • • • • • • • • • • • • • • • • • | | | | | | | | | END | 1 | | | | | | | This is how we can reference data in another subprogram, process it, and return answers in the initial subprogram. #### Problem 20: Write a subprogram that will add 10 fixed point integer numbers starting at address ELEMENTS and store the result at address SUM. The numbers, however, are in another subprogram. Flowchart: Problem 20 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------| | 1 2 2 4 3 4 7 0 | • 66 77 18 18 14 15 16 17 18 19 20 27 | : 77 27 24 25 36 27 26 26 36 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 30 37 37 | <br> | | 1 1 1 1 1 1 1 | IDENT A | | •<br>• • • • • • • • • • • • • • • • • • • | | | ENTRY A | | 1 | | | EXT EL | EMENTS | <u>.</u><br>Litaiti (1984) | | SUM | BSS 1 | | <u>.</u><br>1 : | | A | BSS 2 | | | | 4 1 4 1 1 1 4 | ENI O. | <b>.1</b> | !<br> | | 141 1 1 1 1 | LDA (8 | () ELEMENTS 21 | | | WEXT. | ADD EL | EMENTS+1,1 | | | | ISK 8, | | | | | SLJ NE | EXT | | | | STA C* | t)Sum | IN THIS BANK | | i 1 i 1 i 1 i 1 | SLJ. A | | | | | ELD | | | | | | | | In another subprogram would be the table ELEMENTS and the symbol declared as an entry point. ## Student Problem 20A: Write a subprogram to calculate $S = .5MV-3.5T^2$ in floating point if S is local and M, V, and T are external. # Problem 20A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|-----------------------------------------------|------------------------------------------------------------------------------------------------------------|----------| | 112121412141719 | w (13 13 14 15 14 17 16 16 20 | 21 <u>[77 77 24 25 26 77 76 27 26 31 32 33 26 25 56 37 36 29 48 </u> | <u> </u> | | | <u> </u> | | | | | <del> </del> | | | | | | | | | | | <u> </u> | | | | +++++++++++++++++++++++++++++++++++++++ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | <del> </del> | | | ## GROUP 21 ## SPECIAL INSTRUCTIONS #### Group 21 #### SPECIAL INSTRUCTIONS | 1. | Equivalence | EQU | |----|--------------------|------| | 2. | Bank | BANK | | 3. | Enter Operand Bank | ENO | | 4. | Call | CALL | These instructions do not fit in any group that we have discussed so far. They can be helpful to the programmer in order to perform various functions. The first instruction equates a symbol to a numeric quantity or expression. When the programmer references the symbol, he is referencing the quantity. The second instruction allows the programmer to define which bank each subprogram is to reside in. By doing so he can position his data better and keep the execution time of his program to a minimum. The third instruction enters the Operand Bank register with any bank term so that future operand bank references will be taken from that bank. The fourth instruction is a pseudo instruction that is placed in the executable portion of the program. The reason is that the assembler converts the CALL to the two instructions: 1. EXT 2. BRTJ (\$) ,,\$ The first instruction defines the called name as being external, and the second instruction performs a bank return jump to that name, setting both the Instruction and Operand bank controls to the bank in which the name resides. ## The EQU Instruction ## FOR M: | LOCATION | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|---|--------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 2 2 4 5 4 7 8 | , | <b>1</b><br>10 11 12 12 12 14 15 16 17 16 16 20 21 2 | 77.1,27.1.24.1.25.1.26.1.27.1.26.1.29.1.26.1.31.1.32.1.53.1.44.1.25.1.54.1.27.1.36.1.27.1.46 | 41 42 43 44 45 44 45 44 45 46 47 48 51 52 55 56 59 56 57 58 59 50 41 42 43 44 45 46 47 48 49 49 47 47 48 49 49 49 49 49 49 49 | | l | | EQU m | | | | | | | | | The EQU instruction equates a location field symbol with an address field expression. Any symbol in the address field must have been previously defined. The symbol in the location field will be assigned the value in the address field wherever it is found in the subprogram. ## The BANK Instruction ## FOR M: | LOCATION | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |------------------------|---|----------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------| | 7 12 13 14 15 14 17 14 | , | 10 11 17 13 14 15 14 17 16 10 20 2 | 41 172 37 34 25 36 27 78 28 30 31 32 35 34 35 36 37 38 27 | <br> | | | Γ | BANK | a) NAME, (a) NAME, | | | | | | | <u> </u> | The BANK instruction defines into which bank subprograms are to reside. The address field contains one or more bank terms, each followed by one or more names which represent entry points or common blocks. #### The ENO Instruction #### FORM: | | LOCA | TION | | OPERATION, MOD | OFFIER: | S ADDRESS | FIELD | | COMMENTS | |---|-------------|----------|---------|----------------------------------|--------------|-----------------------------------------------------|-------|-------------------------------------|----------| | | 2 [ 2 ] 4 ] | 3 14 17. | , , | 80 11 17 15 14 15 14 | 7 (30 ) (9 ) | 26 23 72 29 24 25 24 27 28 28 3 | | 134 37 38 3 <del>1</del> 40 | <br> | | | | | $\perp$ | ENÓ | <u> </u> | <b>3</b> | | | 1 | | L | | | | | | 4 1 1 1 1 1 1 1 1 1 1 | | 1 1 1 1 1 | | The ENO instruction is a hardware instruction that changes the Operand Bank register to any one of the 8 possible banks. If this instruction changes the Operand bank register, it will remain so until it is explicitly changed again. The following two sets of coding will do the same thing and each set takes up 48 bits. | Set 1: | $\mathtt{EN} oldsymbol{\wp}$ | 2 | | |--------|------------------------------|----------|----------------| | | LDA | DICT | DICT IN BANK 2 | | Set 2: | LDA | (2) DICT | DICT IN BANK 2 | ## The CALL Instruction #### FORM: | LOCATION | П | OPERATION, MODIFIER | RS ADDRESS | FIELD | COMMENTS | |-------------------------------|---|-------------------------------------------------|------------------------------------------------------------|------------------------------------------------|--------------| | 1 1 2 1 5 1 4 1 5 1 4 1 7 1 8 | , | 30 11 12 13 14 15 16 17 16 19 | <br> 20 21 22 23 24 25 26 27 28 28 30 | 35 32 33 34 35 36 37 38 39 4 | <br> | | | | CALL | NAME | | <u> </u><br> | | | П | | <u> </u> | <u> </u> | | The CALL instruction defines the symbol appearing in the address field as an external symbol and assembles a bank return jump to the symbol. If NAME is a symbol, the assembly would take place as follows: CALL NAME becomes BRTJ (\$)NAME,,\$ EXT NAME The bank return jump is made to the bank in which name resides. The Operand bank register is also changed to that bank. This instruction is much like the Fortran CALL statement which can call a subroutine. #### NEW CONCEPTS OF GROUP 21 The EQU instruction can be used to equate symbols to numbers. The programmer can refer to the symbol instead of the number, and can remember it easier since symbols are easier to remember than numbers. For example, checking for the symbol COMMA is easier than checking for 73B. The BANK instruction will allow the programmer to place the most interactive subprograms in the same bank so as to minimize the execution time. The ENO instruction is simply a convenient method to change the Operand bank control. The CALL instruction is also a convenient method to transfer program control to an external subroutine. ## Problem 21: Given: Subprograms A and B Subprogram B is a subroutine to subprogram A. Subprogram A is entered first. Write the subprograms, such that, subprogram B will calculate $Z = \frac{5X-21}{7}$ in floating point if X, Y, and Z are in subprogram A. Subprogram A should then form R = 5MZ where M is in subprogram B. ## Flowchart: #### SUBPROGRAM A #### SUBPROGRAM B Problem 21 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIER | RS ADDRESS FIELD | COMMENTS | |------------------------|---------------------|----------------------|--------------------------------------------| | 1 12 12 14 15 14 17 14 | | <br> | | | | IDENT | <i>A</i> | | | | ENTRY | $A_{ij}X_{ij}Y_{ij}$ | 1<br> | | 111111 | EXT | M | | | X | BSS | 1 | ASSUME FLOATING POINT<br>WUMBERS PRESTORED | | 7 | BSS | 12 | WUMBERS PRESTORED | | 2 | BSS | 7 | <u>,</u><br>1 | | R | BSS | 12 | <u> </u> | | A | | 2 | <u>!</u><br>! | | | | 8 | GATO (\$ B. SWITCH DBTO THIS<br>BANK | | | FMU | <u> </u> | BANK | | 1 | | (\$)M | EXTERNAL | | | STA | Rillillilli | R=5MZ | | | SLT | <u>A </u> | <u> </u> | | | END | | | | | | 8 | | | | ENTRY | BoM | | | | EXT | X21/21/2 | | | | BSS | <u> </u> | | | $B_{\perp}$ | | 2 | | | | LOA | N | | | | | (*)=D3. | | | | FSB<br>FSB | | 77/2 2-1 | | | | // | 3 <i>X</i> -2 <i>Y</i> | | | 1 - | (*)=D.7- | FIT CR./AI | | | | 18 | EXTERNAL | | | END | | <u> </u> | | | CMN | | | | | | <u></u> | <u> </u> | ## Student Problem 21A: Given: Subprograms A and B Subprogram B is a subroutine to subprogram A. Subprogram A is entered first. Write the subprograms, such that, subprogram B will compare floating operands at point X and Y, store the larger in the A register, and return. Subprogram A will then form $\mathbb{Z} = 3$ . (A) $\neq 5$ . 2X in floating point. Assume X, Y, and Z in subprogram A. Flowchart: Problem 21A could be solved by coding in the following manner: | LOCATION | ODED ATION MODIFIED | ac Annuese fifth | COMMENTS | |-------------------|--------------------------------------------------|------------------------------------------------------------------------------------|----------------------------------------------| | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | CUMMENIS | | 1,212,14,12,4,7,1 | 9 10 (27 (17 (18 (14 (15 (14 (17 (18 (19 | 20 121 122 125 124 125 124 127 128 128 128 130 132 133 124 125 126 127 128 129 128 | ]<br> | | <u> </u> | | | | | | | | | | | | | <u> </u> | | | + | | <u> </u> | | | <del> </del> | <u> </u> | <u> </u> | | | | <u> </u> | | | | | <u> </u> | <u> </u> | | | 1 | <u>L. i., i., i., i., i., i., i., i., i., i.</u> | <u>I </u> | | | | | <u> </u> | | | | | | | | | | | | | | <u> </u><br> | 1<br>1 , , , , , , , , , , , , , , , , , , | | | | <u> </u><br> | <u> </u> | | | | | <u> </u> | | | | | | | | | | | | | | | | | | <del> </del> | <u> </u> | 1 | | | + | | <u> </u> | | | | <u> </u> | | | | | | | | | | <u>1 </u> | <u> </u> | | | | | | | | | | | | | | | | | | | | 1<br>1 <u></u> | | | | 1 | I | ## GROUP 22 ## GLOBAL STORAGE ALLOCATION #### GROUP 22 #### GLOBAL STORAGE ALLOCATION Block Common Originate Relative Counter ORGR The first two instructions declare a block of storage which is not within a subprogram, but common to it. These instructions are comparable to the BSS instruction except that it is local and these are global. The third instruction originates the relocatable counter to any position in the common area. The normal instructions used to prestore data (DEC, etc.) follow this instruction. The data is then assembled into the common area. The instruction ORGR \* returns the relocatable counter to the point from which it left. The instructions following this instruction would then be assembled within the subprogram. The ORGR instruction can also be used to prestore data in the subprogram. #### The BLOCK Instruction #### FORM: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |----------------|----------------------|----------------------------------------------------------------------------------------|----------| | 11212141114121 | | 23 24 25 26 27 28 29 30 31 33 35 34 37 34 27 38 39 4 | | | | DIACH | | | | | ! | | <br> | The BLOCK instruction defines a block of common. The name of the block is defined by the symbol in the location field. There are three possible types of common. - 1. Labeled Common - 2. Numbered Common - 3. Blank Common - 1. Labeled Common is declared if the location field contains a legal alphanumeric symbol. - 2. Numbered Common is declared if the location field contains a number. If it does, all characters must be numbered. - 3. Blank Common is declared if the location field is blank. The definitions of these types of common are given later. The value in the address field specifies the total maximum length of the common block. The value must be greater than or equal to the total length specified in subsequent COMMON instructions. An address field containing zero or blank will set no limit on the size of the block and the size is determined by the amount of storage words declared by the subsequent COMMON statements. A block of common may not exceed one bank of memory and must be self-contained in one bank. #### The COMMON Instruction #### FORM: | LOCATION | | OPERATION, MODIFIERS | S ADDRESS FIELD | COMMENTS | |-------------------------------|---|-------------------------------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 2 3 4 5 4 7 8 | , | 19 ; 11 12 13 14 15 16 17 16 19 | 0 [23 : 77 ] 29 : 34 : 25 : 36 : 37 : 76 : 29 : 36 : 31 : 32 : 93 : 34 : 25 : 34 : 37 : 38 : 9 | <br> 10 41 42 45 46 47 48 48 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 58 | | | | | $A(I,J,\ldots)$ , $B(I,J,\ldots)$ | | | | | | | | The COMMON instruction follows the BLOCK instruction and declares the arrays to be declared in the common block. The address field consists of one or more subfields, each of which defines an array to be included in the block. An array is represented by A(i, j, k, ..., n) where the number of words reserved is the product of the dimensions. #### The ORGR Instruction #### FORM: | LOCATION | | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-------------------------------|---|--------------------------------------|-------------------------------------------------------------------------------------|-----------------------------------------------------------------------| | 1 2 3 4 5 4 7 4 | , | անդություն լերյան, անյուրանայան<br>- | . 20 j 21 : 22 : 25 j 24 : 25 j 24 : 27 ; 28 ; 29 j 20 j 21 ; 32 ; 13 j 24 ; 25 j 1 | <br> <u> 18 25 30 20 48 48 48 48 48 48 48 48 48 48</u> | | | | 1000 | | | | | | | | | The ORGR instruction may be used at any point in the subprogram to initiate a sequence of instructions or constants at a location different from the current program location. The address field contains an expression which must result in a program or labeled common relocatable value. Subsequent instructions or data words are assembled sequentially, beginning at the location specified by that value. This sequence continues until another ORGR instruction is encountered or until the end of the subprogram. The number of words assembled into a labeled common block must not exceed the length of the block. The address field expression may not represent a location in numbered or blank common. When the main subprogram storage assignment sequence is interrupted by an ORGR, the subprogram location counter is saved. An ORGR\* will terminate the assembly of information into an area and return the location counter to the subprogram to the point from which it was interrupted. #### NEW CONCEPTS OF GROUP 22 By having data stored in a common area, subprograms can reference the data without use of external symbols or entry points. The common area physically is a self-contained area but can be referenced quickly and easily if it is declared common to any subprogram. If more than one subprogram declares the same common area, any of them can reference it. There are three types of common as defined on the BLOCK instruction. - 1. Labeled Common - 2. Numbered Common - 3. Blank Common #### LABELED COMMON Labeled common is a common area which is external to, but in common with the sub-program that declares it. Assume subprogram A declares a labeled common area. When the subprogram is loaded, it occupies highest core of the highest available bank. If a system consisted of three banks, the subprogram and common area would be loaded like this: If subprogram B declares the same block of common by specifying the same symbol on its BLOCK instruction, the subprograms will be loaded as such: From this, we can see that labeled common normally precedes the subprogram that defines it, and any other subprogram that defines it is simply loaded and has access to it. Labeled common may be prestored with data using the ORGR instruction. Usually the first subprogram will do it. A common area may also reside in a different bank from the subprogram that declares it. Care must then be taken in the subprogram to specify the bank term when referencing the data. #### NUMBERED COMMON Numbered common is a common area which is external to, but in common with the subprogram that declares it. Assume subprogram A declares a numbered common area. When the subprogram is loaded, it occupies highest core of the highest available bank. The declared numbered common occupies the lowest available core of the same bank. If a system consisted of three banks, the subprogram and common area would look like this: Other subprograms can declare the same numbered common if the identical number is declared on its BLOCK instruction. Other subprograms would be loaded just previous to the given subprogram. If a system has only one bank, bank 0, you will note that a problem arises with respect to the loading of numbered common. Scope cannot be destroyed or the monitoring of the subprogram will not take place. For this reason numbered common starts between Scope and the loader. Since the loader is needed during the loading operation, it is alright to reserve a numbered common area with the BLOCK and COMMON instructions but it is illegal to prestore data in it since the prestored data would overlay (cover) the loader and wipe it out making loading impossible. For this reason it is illegal and an assembler diagnostic to attempt to prestore data in numbered common and blank common (as you will see later). It is legal always to prestore data in a labeled common area. #### **BLANK COMMON** Blank common is just like numbered common (in fact, many refer to blank common as numbered common), except that each blank common declaration overlays the previous blank declaration. This is because there can be no distinction in the location field of the BLOCK instruction since it is always blank. On numbered common, different numbers define different blocks and the distinction can be made. The same is true for labeled common. ## Problem 22: Given: Subprogram A Labeled common block B1 containing address symbols P, R, S, T and the floating point constant . 5. The subprogram and common areas are in different banks. Write subprogram A so that this area is generated and then form P = .5R(S+T). Problem 22 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIES | S ADDRESS FIELD | COMMENTS | |------------------------|---------------------|-----------------------------------------------|--------------------------------------------------------| | 1 [2 [3 [4 [5 [4 [7 [5 | | <br> | <br> | | | IDENT | <b>A</b> | <u> </u><br> <u> </u> | | | FUTRY | <u> </u> | <u> </u> | | B.2 | BLOCK | 5 | | | | COMMON | P, R, S, T, CONI | <u> </u> | | | ORGR | CON1 | [<br> | | | DEC | .5 | <u> </u> | | | PRGR | <u> * </u> | <u></u> | | $A_{\dots}$ | BSS | 12 | <u> </u> | | | LDA | (1)S | <u> </u><br> | | | | <u> </u> | <u> </u> | | | FMU | <u>K </u> | | | | FMU | K. W.1 | | | | 5TA | P | <br> | | 111111 | | <i>A</i> | | | | END | | <u> </u> | | | | | | ## Student Problem 22A: Given: Subprogram A Subprogram B Labeled common B1 containing addresses P, Q, R, S, T, M, and floating point constants . 5 and 36. Write subprogram A to generate this area and form S = .5P(Q-R). Then CALL subprogram B and form M = 36 $\frac{2S-T}{S+T}$ Then return to subprogram A and exit. Assume the subprograms and the common area in different banks. Flowchart: Problem 22A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS ADDRESS FIELD | COMMENTS | |--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 13 19 14 18 14 17 18 1 | • m 23 123 123 124 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 125 1 | 7 40 41 42 45 44 45 46 47 46 48 53 53 54 58 54 57 58 58 58 64 64 65 64 65 64 65 66 75 75 75 75 75 75 | | | | <u> </u> | | | | <u> </u> | | | | | | | | 1 | | | | <u> </u> | | | | | | | <u> </u> | 1 | | | | l . | | | | ! | | <u> </u> | | <u> </u> | | | | | | | | <del></del> | | | | | | | | <del></del> | | | <del></del> | <del>.</del> <del> </del> | # GROUP 23 ## PROGRAMMER MACROS ## GROUP 23 ## PROGRAMMER MACROS Macro MACRO End Macro ENDM The two instructions listed above are the beginning and ending instructions of a macro definition. The macro definition must come immediately after the IDENT instruction. #### The MACRO Instruction #### FORM: | LOCATION | | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |------------------------|---|------------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------| | 1 12 19 14 15 14 17 19 | , | M 13 19 13 14 15 16 17 18 19 | 20 21 27 27 24 25 24 27 28 27 30 31 32 53 34 35 34 27 38 27 38 27 | [4] [42] [42] [44] [45] [44] [45] [44] [45] [45] [55] [5 | | $\ell$ | | | (formal parameters) | | | | | | | | The MACRO instruction signifies the beginning of a macro definition. The location field contains the name of the macro. The name of the macro may be any legal alphanumeric symbol except IDENT, END, MACRO, IFT, IFF, ENDM, LIBM, or SCOPE. The address field may be blank or may contain a set of <u>formal</u> parameters. The formal parameters are also placed in any field in the macro definition and are substituted by <u>actual</u> parameters during the assembly of the subprogram. The set of parameters should be enclosed in parentheses. Formal parameters are separated by commas and must be legal alphanumeric symbols. ## The ENDM Instruction ## FORM: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |---------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------|----------| | 1 2 2 4 5 4 7 8 9 | 10 [ 11 ] 12 ] 13 ; 14 [ 15 ] 16 ; 17 [ 16 ] 19 [ 20 ] 21 ; 22 ( 27 | 1 30 : 27 : 1 20 : 27 : 28 : 20 : 30 : 31 : 32 : 33 : 24 : 35 : 36 : 37 : 36 : 39 : 46 | <br> | | | ENOM | | | | | | | 1<br> | The ENDM instruction terminates a macro definition. #### NEW CONCEPTS OF GROUP 23 A programmer macro is an inline subroutine. The macro is defined and then it may be called at various places in the program with parameter substitutions. Each time it is called, the macro is inserted within the subprogram and the coding is assembled. If a macro is defined, it must be done so immediately after the IDENT instruction. #### Problem 23: A two dimensional 3 x 3 array is shaped according to the matrix as shown here: | | ARRAY | | |-----|-------|-----| | A11 | A12 | A13 | | A21 | A22 | A23 | | A31 | A32 | A33 | | | | | The array is arranged in row-column fashion where A(1,1) represents row 1-column 1, A(2,1) represents row 2-column 1, etc. The array exists in memory as one column as given here: - 1. A11 - 2. A21 - 3. A31 - 4. A12 - 5. etc. From this it is apparent that element A11 is in address A, element A21 is in address A+1, etc. Write a subprogram that will; - 1. contain a macro that will return in the A register the contents of the memory address of an element specified by its coordinates. - 2. multiply the diagonal elements A11, A22, and A33, in floating point and store the result at Z. If A(I, J) represents a given array, an element A(i, j) of the array can be converted to a memory address by the formula; $$A(i, j) = A + (i-1) + (j-1) *I$$ Problem 23 could be solved by coding in the following manner; | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------| | 1 2 2 4 3 4 7 4 | ៖ <u>គេរបស់សក់លើសកែល</u><br>ព្រំ | # <u>[21 #2 #3 #4 #3 #4 #2 #3 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #4 #5 #5</u> | <br> | | | | MATMUL | <u> </u> | | RETURN | MACRÓ | $(P1_{2}P2)$ | !<br> | | | | 4+P1+3*P2-4 | FONVERTED ADDRESS | | | ENDM | | | | | | MATMUL | <u> </u><br> | | 2 | | 2 | 1<br>1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | <i>A</i> | BSS | 9 | HARAY | | MATMUL | BSS | 2 | <u>!</u><br> | | | RETURN | (1,1) | !<br><u> </u> | | | | 7 | | | | RETURN | (2,2) | <u> </u><br> | | | FMU | 2 | 1<br>1 | | | | 2 | 1<br>1 | | | RETURN | (3,3) | <u> </u> | | | | 2 | | | | 1977 | <del>Z</del> | | | | \$4J | MATMUL | | | | END | <u> </u> | | ## Student Problem 23A: Assume problem 23 conditions except here we have a three dimensional, 9 x 9 x 9 array. | A121 | A191 | |------|------| | A221 | A291 | | | • | | | • | | • | | | A921 | A991 | | | A221 | The second through ninth planes are suffixed with the same numbers except the last digit is two through nine. Write a subprogram that will; contain a macro that will return the value of an element to the A register if its coordinates are given in the macro call. If the memory layout is again like problem 23, the formula is; $$A(i, j) = A + (i-1) + (j-1) *I + (k-1) *I *J$$ 2. form the product of the diagnal from one corner to its opposite. This would include elements A111, A222, A333, etc., all multiplied. Store the result at address Z. | _ | | • | | | |------|-----|-----|-------|---| | н 1 | OW | cha | rot . | ۰ | | т. т | .UW | CHA | . I L | ۰ | Problem 23A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIER: | S ADDRESS FIELD | COMMENTS | |----------------|--------------------------------------------------|------------------------------------------------------------------------------------------------------|---------------------------------------------------| | 12221418141714 | <br> | 78 [2] :77 [ 29 24 25 26 27 28 29 36 31 32 33 36 35 36 37 38 39 46 | <br> | | | | | | | | | <u> </u> | | | | ++ | | | | | | | | | | | | | | | | | | | | | | <br> | | | | <u> </u> | | | | <del> </del> | | | | | <del> </del> | | | | | + | | <del> </del> | | | | | | | | | | | | | | | | | | | | | | | | | | # GROUP 24 # ECHO AND IF INSTRUCTIONS ## GROUP 24 ### ECHO AND IF INSTRUCTIONS | 1. | Echo | ECHO | |----|-----------------|--------| | 2. | If Non-zero | IFN | | 3. | If Zero | IFZ | | 4. | If Inequalities | IF, s | | 5. | If Upper | IFU | | 6. | If Lower | IFL | | 7. | If True | IFT, s | | 8. | If False | IFF, s | | 9. | End If | ENDIF | The first instruction is a pseudo instruction that repeats a succeeding series of instructions or data. Each time the series is repeated different parameters can be substituted. The other eight instructions are pseudo instructions that answer questions at assembly time. Should the assembler assemble a series of coding or should it bypass it? If yes, the succeeding coding will be assembled and entered as part of the program. If no, the succeeding coding is skipped. ### The ECHO Instruction #### FOR M: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |--------------------------|----------------------|-------------------------------------------------------------------------------|--------------------------------------------------| | 1 12 12 14 13 14 17 18 2 | <br> | 3a : 55 : 34 : 37 : 28 29 : 38 31 32 : 33 34 35 34 : 37 : 38 : 39 | <br> <u> </u> | | l | ECHO man | (P1 = A1, A2, P2 | = B1, B2, ···) | | | | | <u>, , , , , , , , , , , , , , , , , , ,</u> | The ECHO instruction is a pseudo instruction that causes the succeeding $\underline{m}$ lines of coding to be assembled $\underline{n}$ times. Each time the $\underline{m}$ lines are assembled, actual parameters $\underline{a}$ , $\underline{b}$ , $\underline{c}$ , etc. may be substituted for the formal parameters $\underline{p}_1$ , $\underline{p}_2$ , $\underline{p}_3$ , etc. If no parameters are to be substituted, the column after the $\underline{n}$ are left blank. The formal parameters must be alphanumeric symbols. The actual parameters may be any expressions which legally may appear where the formal parameters occur. Location symbols within the range of an ECHO are assigned only in the first repetitions in order to prevent doubly defined symbols. ## The IFN Instruction ### FORM: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |--------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------------|----------| | 1 12 12 14 14 14 17 14 | 9 10 11 17 13 14 15 14 15 16 17 16 19 20 21 22 | 29 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | | | | IFN | 4 ! 1 1 1 1 1 1 1 1 1 | . | | | | | | | <del> </del> | | | | The IFN instruction is a conditional pseudo instruction that checks the value of $\underline{m}$ for non-zero. If the value is non-zero, the next $\underline{p}$ lines of coding will be assembled. If the value is zero, the next $\underline{p}$ lines of coding are skipped and are not included in the assembly of the subprogram. Both $\underline{m}$ and $\underline{p}$ are evaluated as 15-bit quantities. If $\underline{p}$ and the preceding comma are omitted, the range of the IFN is determined by an ENDIF pseudo instruction. ## The IFZ Instruction ### FORM: | LOCATION | | OPERATION, MODIFIER | RS ADDRESS F | IELD | COMMENTS | |------------------|---|--------------------------------------|---------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------| | 1.12121415141714 | , | ալու <u>տյալալայա</u> յուայ <u>ա</u> | <br> 20 21 22 23 24 25 24 27 78 28 28 21 ; | 32 : 32 34 35 36 36 36 36 36 36 36 | 41:42:43;44;44;44;44;44;44;44;44;44;44;43;43;4 | | 1 1 1 1 1 1 1 | | Tea 1 | <br> M.: | | | | | 1 | | | | | The IFZ instruction is a pseudo instruction that checks for the opposite condition of the IFN instruction. For this instruction, if the value $\underline{m}$ is zero, the following $\underline{p}$ lines of coding are assembled. If the value is non-zero, the following $\underline{p}$ lines of coding are skipped. The IF, s Instruction ### FORM: | LOCATION | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------------|---|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------| | 1,12,19,14,15,14,7,18 | , | անլուլուլուլույ <sub>ան ա</sub> լուլուլուլույու <sub>ն</sub> ույու | 7 27 24 25 26 27 28 26 30 31 32 35 34 35 34 37 38 39 40 | <br> | | | | TEC | | | | | | | | | The IF, s instruction is a conditional pseudo instruction in which the operation field modifier $\underline{s}$ represents the condition compared. The $\underline{s}$ modifier may be replaced by any of the following: | Mnemonic | Meaning | |----------|------------------------------| | EQ | m = n | | NE | m ≠ n | | LT | m < n | | LE | $m \leq n$ | | GT | m > n | | GE | $\mathbf{m} \geq \mathbf{n}$ | The next $\underline{p}$ lines of coding will be assembled if the relationship specified by the instruction modifier $\underline{s}$ exists between $\underline{m}$ and $\underline{n}$ . The next $\underline{p}$ lines are skipped, if the specified relationship does not exist. ### The IFU Instruction #### FOR M: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |------------------------|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------|---------------| | 1 12 12 14 15 14 17 18 | <br> 100 111 122 123 144 155 145 157 138 158 123 122 | 29 24 25 26 27 28 29 36 31 32 35 36 35 36 37 38 39 | | | | KFU | | •<br><u> </u> | | | 1 | <u> </u> | <u> </u> | The IFU instruction is a conditional pseudo instruction that checks to see if the preceding instruction was assembled in the lower half of the memory word. If it was, the next $\underline{p}$ lines are assembled. If it wasn't the next $\underline{p}$ lines are skipped. If $\underline{p}$ is omitted, the range of the IFU is determined by the ENDIF pseudo instruction. ## The IFL Instruction ### FORM: | LOCATION | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |------------------|---|----------------------------------------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------| | 1.12191415141714 | , | 10 11 17 17 14 15 14 17 16 19 20 21 22 | 19 34 25 36 37 28 28 36 31 33 33 36 35 36 37 38 39 44 | <br> 41 42 43 44 45 44 47 48 49 58 43 28 43 58 35 58 37 38 39 48 43 43 43 43 45 46 47 48 48 79 71 73 | | | | I.F.L. | | | | | | | | !<br> | The IFL instruction is a conditional pseudo instruction closely related to the IFU instruction except that, if the preceding instruction was an upper instruction, the next $\underline{p}$ lines are assembled. If the preceding instruction was not an upper instruction, the next $\underline{p}$ lines are skipped. ### The IFT, s Instruction #### FORM: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------|-----------------------------------------------------------------------------------------------|----------| | 1 2 2 4 5 4 7 8 | <br> | 1 27 1 28 1 28 1 28 1 30 1 27 1 28 1 29 1 30 1 31 1 32 1 33 1 34 1 37 1 36 1 37 1 38 1 29 1 4 | <br> | | | TOT | · <b>Σ 2 9</b> • • • • • • • • • • • • • • • • • • • | 1 | | | ' ' | | 1<br>1 | The IFT instruction is a conditional pseudo instruction that compares character strings $\underline{m}$ and $\underline{n}$ to determine if coding lines which follow are to be assembled or skipped. This instruction may be used only within the range of an ECHO or MACRO instruction. The modifier s specifies the condition compared and may be any one of the following: | Mnem | onic | Meaning | |------------|------|----------------------------------| | | | | | EQ | | m = n | | NE | | $m \neq n$ | | GT | | m > n | | GE | | m≥ n | | LT | | m < n | | $_{ m LE}$ | | $m \leq n$ | | IN | | m included in n; the character | | | | string n contains the characters | | | | in string m in sequence, but | | | | not necessarily consecutively. | The address field consists of two or three subfields. The $\underline{m}$ and $\underline{n}$ subfields must be present. Any actual parameter must be enclosed with slashes. Either or both subfields may be a single formal parameter as defined on the MACRO or ECHO instructions. Either may be a string of characters enclosed in slashes. If $\underline{p}$ and the preceding comma are omitted, the range of the IFT instruction is determined by the ## ENDIF pseudo instruction. The $\underline{m}$ and $\underline{n}$ subfields may include an optional modifier of the form (i,j) to define a portion of the actual parameter to be used in the comparison. This modifier may not contain formal parameters. The (i,j) modifier may be in one of four forms, in which X, Y and Z represent integers and K represents any non-blank BCD character except slash. | FORM | INTERPRETATION | |---------------------------------------------------------------------|--------------------------------------------------------| | (X, Y) | Y consecutive characters beginning with | | | the xth character of the actual parameter. | | (Z = K, Y) | Y consecutive characters following the | | | Zth occurrence of the character K. | | (X, Z=K) | Consecutive characters beginning with the | | | Xth character up to, but not including, the | | | Zth occurrence of the character K follow- | | | ing the Xth character. | | $(\mathbb{Z}_1 = \mathbb{K}_1, \mathbb{Z}_2, \bullet \mathbb{K}_2)$ | Consecutive characters following the $\mathbf{Z_1}$ th | | | occurrence of character ${ m K}_1$ up to, but not | | | including, the Z2th occurrence of character | | | к <sub>2</sub> . | | | | The IFF, s Instruction ## FORM: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------|-----------------------------------------------------------------------|----------| | 1 2 2 4 4 4 7 4 | <br> | 29 24 25 26 27 78 29 30 3 3 3 3 3 3 3 3 | | | | 1 . | | 1 | | | | • | <u> </u> | | | | | 1 | The IFF instruction is a conditional pseudo instruction that is the same as the IFT instruction except that it tests for the opposite condition. #### The ENDIF Instruction #### FOR M: | LOCATION | OPERA | TION, MODIFIEI | RS | ADDRESS | FIELD | | | | COMM | ENTS | | | | |------------------------|---------------|--------------------|------------------------------|---------------------------------------------------|----------------------------------------|------------------------|----------------------------------|------------------------|-------------------------------|------------------------------|-------------------|-------------------|-------------------| | 1 12 13 14 15 14 17 18 | . 10:1:1:37 [ | ուսյուն ուրայլայլա | <br> 20 21 72 23 24 | 25 j 26 j 27 j 28 · 29 j 36 j 1 | U 1 32 ; <b>1</b> 5 <u>1 34 ; 28 j</u> | N4 37 38 39 40 | 41 42 43 44 45 46 47 | 48 ; 49 ; 55 ; 51 ; 52 | _53 <u> 54 55 36 </u> 5 | _ 58 ; 59 ; e0 ; 61 <u>;</u> | n2 +2 54 65 | 900 67 MB 6 | 19 70 73 72 | | | END | IF | NAME | | | 1 1 1 | | | | 1 1 1 1 1 | ii | | | | | | | <b>!</b> | | 1 1 1 1 1 | | | | | | 1 1 1 | 1 1 1 1 | | | | 1 | | 1 | man de commente en confere e en borro será monero | | | | | | | | | | The ENDIF instruction is a pseudo instruction which defines the limit to a conditional IF instruction not containing a line count. If lines are skipped because of a conditional IF, the associated ENDIF causes normal processing to resume. The associated IF and ENDIF instructions are related by the location field symbol on the IF instruction and the address field symbol on the ENDIF instruction. If these symbols match, the IF is terminated. An ENDIF with a blank address field is associated with the last encountered unlabeled IF. If the symbols do not match, the IF is not terminated and counts as a line of coding. #### NEW CONCEPTS OF GROUP 24 The ECHO instruction is different from the IF instructions in that the ECHO instruction is not a conditional pseudo. The ECHO instruction can duplicate a series of coding with possible parameter substitution. If the programmer wishes to prestore alternating positive and negative zeros in core in order to perform some hardware test, he can do so simply in the assembly of the program by coding; ECHO 1,500 OCT 0,-0 The OCT instruction is assembled 500 times and each time it prestores positive and negative zero. The total amount of core used is 1000 locations. The IF instructions are used to determine which sets of coding to assemble. If some condition is true, then assemble the coding. If it is not true, then skip the coding. One example of how the IF instructions can be used is this: Assume an input/output program of approximately 1500 lines of coding. Assume that sometimes it is to be run with the drum as the primary input/output medium and at other times magnetic tape as the primary input/output medium. Now we know that the drum and magnetic tape units are not programmed the same way. Their function codes are different and the data is accessed differently. For each run must we physically remove the set of instructions that does not apply or could we just change one instruction? To solve this problem we recall the EQU instruction (in group 21). With this instruction we can equate a symbol with a constant. Suppose we could enter either of the following instructions at the beginning of the program: 1. DRUMTAPE EQU 1 2. DRUMTAPE EQU 0 If DRUMTAPE = 1 means that the drum coding is to be assembled, and DRUMTAPE = 0 means that the tape coding is to be assembled, by inserting IFZ and IFN instructions at strategic points in the subprogram, only the applicable instructions and data will be assembled. Note how, in the following case, the drum instructions are assembled and the tape instructions are bypassed. | LOCATION | OPERATION, MODIFIES | RS ADDRESS FIELD | COMMENTS | |-------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------|----------| | 1 2 2 4 5 4 7 4 | a 10/13/13/13/14/15/14/15/14 | 100 23 27 27 28 28 25 26 27 28 27 28 28 28 28 28 | <br> | | | IDENT | T.P. | | | | ENTRY | IO | | | DRUMTAPE | Equ | 1 | | | | <del></del> | | | | <u> </u> | | <u> </u> | | | | IFN | DOUGHT 100 10 | <u> </u> | | | | DRUMTAPE, 15 | 1 | | | • FILLE 2 | l | | | | <b> -</b> | | | | | 1. | | | | | IFZ | DRUMTAPE, 10 | | | <u> </u> | | of tape coding) | !<br> | | | <u> </u> | | <u> </u> | | | <u> </u> | | | | | <del>-</del> | | | | | END | | | | | <del> </del> | | | If we change the DRUMTAPE flag to a zero, note how the tape coding would be assembled, and the drum coding would be bypassed. The IFU and IFL instructions can be used to remove NOP's when several conditionals are used. In this way the subprogram can be packed into core as tight as possible. The IFT and IFF conditionals are within the range of ECHO or MACRO instructions and can be used to discard impertinent coding for each generation of the ECHO or MACRO. Problem 24 illustrates this use. ### Problem 24: Write a subprogram that contains a MACRO definition and a MACRO call. The MACRO definition makes use of IFT instructions that allows bypassing irrelevant coding for each individual macro call. This particular macro definition is one that sets the operating mode of a tape unit on channel #1. It has two formal parameters, P1 and P2 which are defined as follows: | Formal Parameter | Meaning | |------------------|---------------------------------------------------| | 1. P1 | Format - the format may be BCD or binary. | | 2. P2 | Density - the density may be 200, 556 or 800 BPI. | The name of the macro is OPMODE. | $\Phi$ DM $\Phi$ DE | $\mathbf{n} \mathbf{r} \mathbf{\Lambda} \mathbf{C} \mathbf{D} \mathbf{\Lambda}$ | /D1 D0\ | |---------------------|---------------------------------------------------------------------------------|----------| | <b>ØPMØ</b> DE | MACRØ | (P1, P2) | For the actual call of the macro any of the following calls are legal: | 1. | <b>ØPMØDE</b> | (BCD, 200) | |----|----------------|------------| | 2. | <b>ØPMØ</b> DE | (BCD, 556) | | 3. | <b>ØPMØDE</b> | (BCD, 800) | | 4. | <b>ØPMØ</b> DE | (BIN, 200) | | 5. | <b>ØPMØ</b> DE | (BIN, 556) | | 6. | <b>ØPMØ</b> DE | (BIN, 800) | For any of the six possible calls, only the applicable coding should be assembled. Use the IFT instruction in the macro definition, and then, as an example, call OPMODE specifying BIN format at 556 BPI. The macro should set the tape unit to this operating mode (requires EXTF instructions). Problem 24 could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-----------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------| | 112121415141718 | ៖ (ស <sub>ុ</sub> កា[កេញស្គា] អេក្សា (ស | 20 21 22 23 24 25 26 27 28 27 28 28 31 32 35 34 35 36 27 38 27 38 | 41 42 43 44 45 56 47 46 47 56 53 55 55 55 55 55 55 | | | | MODE | <u> </u> | | PPMODE | MACRO | (P1, P2) | <br> | | | IFT, EQ | P1, /BCD/21 | | | | EXTE | 1,2,1 | SET. T. BCD | | | IFT, EQ | Pla/BIN/ | [ | | | EXTE | 2,1,* | SET TO BIN | | 4 1 1 1 1 1 1 | IFT, EQ | P2,/200/,1 | | | | EXTE | 1.9.4.* | 200. BP I | | | I FT, EQ | P2, 1556/, 1 | <br> | | | | 1,3,* | 556 BPI | | | IFT, FQ | P2,/800/,1 | | | | | 2,6,3×11111111111111111111111111111111111 | BOO BPI | | | ENDM | | | | <u> </u> | ENTRY | MOE | | | MADE | $B$ $\zeta$ , $S$ | | | | | &PMODE. | (BIN, 556) | | | | | MODE | | | | END. | | | ## Student Problem 24A: This problem is similar to problem 24 except that, when the subprogram is entered, the A register contains a floating point number. Write a subprogram that contains a macro definition named VELOC with two parameters, P1 and P2 defined as such: | <u>Parameter</u> | Meaning | |------------------|------------------------------| | P1 | Increase (A) or Decrease (A) | | | INCRA or DECRA | | P2 | .05 or .1 | The four possibilities for the macro call would be; | 1. | VELØC | (INCRA, . 05) | |----|----------------|---------------| | 2. | VELØC | (INCRA, . 1) | | 3. | VELØC | (DECRA, . 05) | | 4. | VEL <b>Ø</b> C | (DECRA1) | From the four choices we can increase (A) by 5 or 10% or decrease (A) by 5 or 10%. Set up the macro definition so that assembly of only the necessary lines will take place. Then decrease the velocity by 10% by calling the macro. Flowchart: Problem 24A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------| | 112121413141714 | | <u> 28 34 25 36 37 28 28 36 31 32 33 34 35 36 37 38 39 40</u> | 41;42;43;44;45;44;45;44;45;45;35;35;45;35;45;35;45;45;45;45;46;45;46;45;46;45;46;45;46;45;46;45;46;45;46;46;46;46;46;46;46;46;46;46;46;46;46; | | | | <del>i </del> | | | <del> </del> | <del> </del> | | <u> </u> | | | +++++++++++++++++++++++++++++++++++++++ | <u> </u> | | | 11:::::: | | | | | | | | | | | | | | | | <u> </u> | | | | <del></del> | <del> </del> | <del></del> | | | 11111 | | | | | | <del> </del> | <del></del> | | | | <u> </u> | | | | | | | | | | <del> </del> | | | | | | <u>i </u> | | | | <del> </del> | | | | | + | <del> </del> | | # GROUP 25 LIST CONTROL INSTRUCTIONS #### GROUP 25 ### LIST CONTROL INSTRUCTIONS | 1. | No List | NOLIST | |----|---------|--------| | 2. | List | LIST | | 3. | Space | SPACE | | 4. | Eject | EJECT | | 5. | Remark | REM | | 6. | Title | TITLE | | 7. | Brief | BRIEF | | 8. | Detail | DETAIL | | | | | The instructions listed above do not affect the execution of the program. They are used only for the source listing. The first two instructions allow sections of coding to be deleted. They could be sections that the programmer knows contains no errors and would simply cause unnecessary time and waste if they were listed. The second two instructions make the listing easier to read. They incorporate spacings in the program which separate the various parts. The TITLE instruction puts a title at the top of each listed page. This makes it easy to distinguish at a glance between subprograms and between various portions of a subprogram. The last two instructions allow the deletions of repetitious and extraneous coding. ## The NOLIST Instruction ## FORM: | | LOCA | TION | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |---|-------|---------------|----|------------------------------------------------------|-----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------| | L | 21214 | 1 1 4 1 7 1 1 | 1. | 10 [ 33 [ 32 ] 13 ] 14 ] 15 ; 16 ] 15 ] 16 ] 10 ] 10 | 123 123 23 24 25 34 27 24 25 36 21 37 33 34 23 34 27 38 39 40 | 41.621.62144.651.44.671.44.47.381813315313413813813913913913913913161616416516416516416516917917173 | | L | للتال | نبنا | L | NOLIST | <u> </u><br> | | | L | | | | | <br> | <u> </u> | The NOLIST instruction is a pseudo instruction that suppresses the listing of the source subprogram until a LIST pseudo instruction is encountered. However, lines with error flags will still be listed. ### The LIST Instruction ## FORM: | LOCATION | 01 | PERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|----|-----------------------------------------|----------------------------------------------------------------------------------------------------|--------------| | 1 2 2 4 5 4 7 4 | | [11] [11] [11] [11] [11] [11] [11] [11] | 123 : 22 : 23 : 24 : 25 : 26 : 27 : 26 : 27 : 26 : 26 : 30 : 31 : 33 : 45 : 26 : 37 : 38 : 27 : 48 | <br> | | | 1 | $\mathcal{I}$ s $\mathcal{I}$ | | | | | | | | <u> </u><br> | The LIST instruction is a pseudo instruction that resumes listing of the source subprogram. This instruction is meaningful only if a NOLIST instruction was encountered previously. This instruction will have no effect if the Compass control card does not have the list option specified. ### The SPACE Instruction ### FORM: | LOCATION | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|----|----------------------|-----------------------------------------------------------------------------------------------------------------------|---------------| | 1 2 2 4 5 4 7 8 | l. | <br> | 0 21 172 29 24 25 <u>24 17 18 21 26 26 31 32 35 24 25 36 27 38 39 46 </u> | <br> | | | | SPACE | | !<br><u> </u> | | | | | | <u> </u><br> | The SPACE instruction is a pseudo instruction that spaces the output listing the number of lines specified by $\underline{n}$ . If the spacing would cause an overflow at the bottom of a page, an eject takes place to the top of the next page. ## The EJECT Instruction ## FOR M: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------|----------------------------------------------------------------------------------------------|----------| | 1 2 2 4 5 4 7 6 | <br> | 12 23 24 25 26 27 28 29 36 31 32 33 34 35 34 37 38 39 40 | <br> - | | | EJECT | | | | 1 1 1 1 1 1 | | | | The EJECT instruction is a pseudo instruction that causes the printer to eject the source listing to the top of the next page. ## The REM Instruction ## FOR M: | LOCATION | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-------------------|---|----------------------|---------------|----------------------------------------------------------------------------------------------------------------| | r12:3:4[\$14:7]\$ | | <br> | | 41:42:43:44:45:44:45:44:47.48:47:56:55:55:55:55:55:55:55:55:56:55:56:55:66:45:45:45:46:45:46:45:46:45:46:46:46 | | | L | REM | 4 | | | | Γ | | | , | | | Т | 1 | l l | | The REM instruction is a pseudo instruction that produces on the listing a line of printed remarks only. If the remarks exceed one line, they can be continued on the next line if a column 10 REM is repeated. ## The TITLE Instruction ### FORM: | LOCATION | | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |-----------------|---|----------------------------------------------------------------------------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 112121411141714 | , | 16 (17 (17 (18 (14 (18 (16 (17 (18 (19 (19 (19 (19 (19 (19 (19 (19 (19 (19 | 5 <u> 24 27 28 28 28 </u> 31 <u> 33 34 35 34 37 38 37 </u> | 41;42;45;44;45;44;45;44;45;44;45;55;51;52;53;54;135;54;37;58;57;44;45;43;43;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;44;45;45 | | | | TITLE | | | | | | | | | The TITLE instruction is a pseudo instruction which may appear anywhere in a subprogram after macro definitions and before the END instruction. The first TITLE instruction, no matter where it appears, will have columns 16-72 printed on the top of the first page of the subprogram listing and at the top of all subsequent pages until another TITLE instruction is encountered. Second and subsequent TITLE instructions will cause a page eject. If TITLE is not used in a subprogram, the contents of the IDENT address field will be printed as the title. #### The BRIEF Instruction #### FORM: | LOCATION | | OPERATION, MODIFIER | S ADDRESS FIELD | COMMENTS | |-------------------------------|---|------------------------------------------------------|------------------------------------------------------------------------------------------------------------|----------| | 1 2 2 4 5 4 7 4 | , | 16 17 17 17 18 14 15 16 17 18 19 | 80 j 21 ; 22 j 25 j 24 j 26 j 26 j 27 ; 28 j 28 j 28 j 30 j 31 j 32 j 33 j 24 j 25 j 26 j 27 ; 28 j 29 j 4 | <br> | | | | BRIEF | | <u> </u> | | | | | <br> | <u> </u> | The BRIEF instruction is a pseudo instruction that deletes the listing of the following: - 1. the area set aside for literals. - 2. all but the first full word generated by OCT, DEC, and DECD instructions. - the second half word and all subsequent words generated by TYPE, BCD, and VFD instructions. - 4. location digits of second and subsequent array names of a COMMON pseudo instruction. BRIEF may occur at any point in a program after macro definitions. It remains in effect until a DETAIL pseudo instruction is encountered. ## The DETAIL Instruction ## FORM: | LOCATION | OPERATION, MODIFIERS | S ADDRESS FIELD | COMMENTS | |-------------------------------|----------------------|------------------------------------------------------------------------------------------------------|----------| | 1 2 3 4 5 4 7 8 | • ## | 0 [21 77 77 24 25 26 77 78 27 30 31 32 33 34 37 36 37 38 39 40 | <br> | | | DETAIL | | | | | | | | | 1 | 1 | | | The DETAIL instruction is a pseudo instruction that causes a return to the normal listing mode that was suppressed by the BRIEF pseudo instruction. ### NEW CONCEPTS OF GROUP 25 It is important to note that the instructions in this group affect only the source listing. They do not control the output generated during the execution of the program. We might say that these instructions add a helpful aid to anyone analyzing a large program. If spacings are allowed to separate important areas, if remarks are included at the beginning of each area, and if areas are entitled at the top, it makes it much easier to read and understand. In order to show how these instructions affect the listing, problem 25 is a little different than the problems previously presented. # Problem 25: Write a subprogram that will illustrate the use of the SPACE, REM, TITLE, NOLIST, and LIST pseudo instructions. Problem 25 could be solved by coding in the following manner: | LOCATION | OPERATION, MOD | DIFIERS ADDRESS FIELD | COMMENTS | |-----------------------------|----------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | OUR MEN 13 | | 1 12 13 1 1 1 1 1 1 1 1 1 1 | IDENT | 12.LU.S.T | (1) [46] 46 [47] 44] 49; 55; [51; 52; 53; 141; (55; 56; 57; 56; 56; 66; 62; 62; 62; 64; 65; 64; 65; 64; 65; 64; 65; 64; 65; 64; 65; 64; 65; 64; 65; 64; 65; 64; 65; 64; 65; 64; 64; 64; 64; 64; 64; 64; 64; 64; 64 | | | ENTRY | TLLUST | <del></del> | | <u> </u> | REM | THIS IS A DØ NOTHING | | | | REM | PROGRAM FOR ILLUSTRATION | 1 4 4 3 1 | | | SPACE | FROGRAM LAK ICLUS/RAILIA | V (QML)7. • | | -1-1-1-1-1-1 | | 14/C 114/C 7/1 0.2 - C 0 ml 1 | - 1 | | -1 | REM | WE HAVE JUST SPACED 5 L. | LNES | | | REM<br>REM | AND WE SPACE 5 MORE IN | <u> </u> | | | | ORDER TO SEPARATE THIS | AREA. | | <u> </u> | SPACE | <u> </u> | 4 1 1 2 2 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 | | | REM | NOW LET'S ENTITLE THIS | PAGE. | | | REM | YOU SHOULD SEE NUTGOODY | | | | REM | AT THE TOP. | <u> </u> | | | TITLE | NUTGOODY | <u> </u> | | | REM | NOW LET'S START | <u> </u> | | | REM | OUR PROSRAM- | | | ILLUST | BSS | <u> </u> | | | | L.DA. | CON! | | | | FAD | LLUST | | | | ≤LJ . | ILLUST | | | | SPACE | <u> </u> | | | | REM | LOW LET'S ASSEMBLE | <del></del> | | | REM | THE DECIMAL CONSTANTS | | | | REM | BUT NAT LIST THEM. | <del></del> | | | WOLIST | | <del></del> | | CONI | DEC | 5.6 | <del> </del> | | CONZ | DEC | 1-3-8 | <u> </u> | | 98/40 | 475T | 1 2 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | REM | THE COUSTANTS ARE | <del></del> | | | REM | ACTUALLY ACCOUNTS | | | | REM | ACTUALLY ASSEMBLED. | | | | | WO ASSEMBLY ERROR | | | | BEM | APPEARS. | | | | SPACE | | | | <del></del> | REM | THANKS FOR THE SHOW | <u> </u> | | <del></del> | REM | AND NOW WE SAY, | <u> </u> | | THE | REM | | | | | END | | manus personal from the contract of contra | ## Problem 25A: Write a subprogram that will illustrate the use of the EJECT, BRIEF, and DETAIL pseudo instructions. Problem 25A could be solved by coding in the following manner: | LOCATION | OPERATION, MODIFIERS | ADDRESS FIELD | COMMENTS | |---------------------------|------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------------------------------------------------------| | 1 | | | 1 | | 3 9 4 3 4 7 3 | • 10 11 127 13 14 15 14 15 14 15 15 16 15 15 | 2 25 26 25 26 27 28 29 36 31 32 33 34 35 34 37 38 3 | 9, 41 (a) (d) (d) (d) (d) (d) (d) (d) (d) (d) (d | | | | | | | | <del> </del> | 11111111111 | | | | <del> +</del> | | <del></del> | | | | 1111111 | <u> </u> | | | | <u> </u> | | | | <u> </u> | | <u> </u> | | | | | | | | | <u> </u> | | | <u> </u> | | | | | | | <u> </u> | | | | | | | | | | <u>i </u> | | | | | | | | | | | | | | | <u> </u> | | | | | | | | | | | <u> </u> | | <del></del> | | | ··· <b> </b><br>: : <b> </b> | | <del> </del> | | | | | <u> </u> | | | | | <u>1_1_1_1_1_1_1</u> | | | | | <u> </u> | | <u> </u> | | | <del></del> | <del> </del> | | | | | | <u> </u> | | | ے نے دل | | <u> </u> | <u>, , , , , , , , , , , , , , , , , , , </u> | | خاخلىنى | | | | | | | <u> </u> | | | <u> </u> | <del> </del> | | | | | <del> </del> | | <u> </u> | | | | <u> </u> | <u>, , </u> | | | <del> </del> | | <u>, , , , , , , , , , , , , , , , , , ,</u> | | | | | | | 111111 | 1 | | | | | | | <u> </u> | | | 1111111111 | <u> </u> | <u> </u> | | | | | | | | | | 1 | CORPORATE HEADQUARTERS, 8100 34th AVE. SO., INTINNEAPOLIS, MINN, 55440 SALES OFFICES AND SERVICE CENTERS IN MAJOR CITIES THROUGHOUT THE WORLD